blob: 73b6221e9deacb896c1b839591eb5671845a5c9e (
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
|
set test "flightrec1"
if {![installtest_p]} { untested $test; return }
# run stapio in background mode
spawn stap -F -o $test.out -we {probe begin {}}
# check whether stap outputs stapio pid
set pid 0
expect {
-timeout 240
-re {([0-9]+)\r\n} {
pass "$test (flight recorder option)"
set pid $expect_out(1,string)
exp_continue}
timeout { fail "$test (timeout)" }
eof { }
}
wait
if {$pid == 0} {
fail "$test (no pid)"
return -1
}
# check whether stapio is running in background
spawn ps -o cmd hc $pid
expect {
-timeout 10
"stapio" {pass "$test (stapio in background)"} # don't contine
timeout { fail "$test (timeout)"}
eof { fail "$test (stapio was not found)" }
}
wait
# switch file
exec kill -USR2 $pid
# check output file
if {[catch {exec rm $test.out}]} {
fail "$test (no output file)"
return -1
} else {
pass "$test (output file)"
}
exec kill -TERM $pid
# check switched output file
if {[catch {exec rm $test.out.1}]} {
fail "$test (failed to switch output file)"
return -1
} else {
pass "$test (switch output file)"
}
|