blob: 5026e5d0d101efd7bcd1084b2b21aad7368b1b80 (
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
|
# Tests backtrace in the classic Fibonacci program
set test "fib"
# Only run on make installcheck and utrace present.
if {! [installtest_p]} { untested "$test"; return }
if {! [utrace_p]} { untested "$test"; return }
set testpath "$srcdir/$subdir"
set testsrc "$testpath/fib.c"
set testexe "[pwd]/$test"
# We want debug info and no optimization (is that totally necessary?)
set testflags "additional_flags=-g additional_flags=-O0"
set teststp "$testpath/$test.stp"
set res [target_compile $testsrc $testexe executable $testflags]
if { $res != "" } {
verbose "target_compile failed: $res" 2
fail "unable to compile $testsrc"
return
}
spawn stap -c "$testexe 10" $teststp
set fibcalls 0
set maincalls 0
expect {
-timeout 120
-re {^fib[^\r\n]*[\r\n]} { incr fibcalls; exp_continue }
-re {^main[^\r\n]*[\r\n]} { incr maincalls; exp_continue }
-re {^[^\r\n]*[\r\n]} {exp_continue}
timeout { fail "$test (timeout)" }
eof { }
}
wait
if {$fibcalls == 18 && $maincalls == 2} { pass "$test ($fibcalls $maincalls)" } { fail "$test ($fibcalls $maincalls)" }
spawn stap -c "$testexe 10" -- $teststp --entry
set fibcalls 0
set maincalls 0
expect {
-timeout 120
-re {^fib[^\r\n]*[\r\n]} { incr fibcalls; exp_continue }
-re {^main[^\r\n]*[\r\n]} { incr maincalls; exp_continue }
-re {^[^\r\n]*[\r\n]} {exp_continue}
timeout { fail "$test (timeout)" }
eof { }
}
wait
if {$fibcalls == 55 && $maincalls == 10} { pass "$test ($fibcalls $maincalls)" } { fail "$test ($fibcalls $maincalls)" }
|