summaryrefslogtreecommitdiff
path: root/tests/detach-sleeping.test
blob: 92138b53b50e795cf9e5cc08108b05c37bac2841 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
#!/bin/sh

# Ensure that strace can detach from sleeping processes.

. "${srcdir=.}/init.sh"

check_prog sleep
check_prog grep

set -e

rm -f $LOG
./set_ptracer_any sleep $((2*$TIMEOUT_DURATION)) > $LOG &

while ! [ -s $LOG ]; do
	kill -0 $! 2> /dev/null ||
		fail_ 'set_ptracer_any sleep failed'
	$SLEEP_A_BIT
done

tracee_pid=$!

cleanup()
{
	set +e
	kill $tracee_pid
	wait $tracee_pid 2> /dev/null
}

rm -f $LOG
$STRACE -p $tracee_pid 2> $LOG &

while ! grep -F "Process $tracee_pid attached" $LOG > /dev/null; do
	kill -0 $! 2> /dev/null ||
		{ cat $LOG; cleanup; fail_ 'strace -p does not work'; }
	$SLEEP_A_BIT
done

kill -INT $!
wait $!

grep -F "Process $tracee_pid detached" $LOG > /dev/null ||
	{ cat $LOG; cleanup; fail_ 'strace -p failed to detach'; }

if [ -f /proc/self/status ]; then
	$SLEEP_A_BIT
	test -d /proc/$tracee_pid ||
		{ cat $LOG; cleanup; fail_ 'tracee died after detach'; }
	grep '^State:.*S (sleeping)' < /proc/$tracee_pid/status > /dev/null || {
		cat $LOG
		grep '^State:' < /proc/$tracee_pid/status
		cleanup
		fail_ 'tracee is not sleeping after detach'
	}
fi

cleanup
exit 0