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 59 60 61
|
set test "mod_init_exit_hooks"
set testpath "$srcdir/$subdir"
set work_dir [pwd]
if {! [installtest_p]} { untested $test; return }
# --- TEST 1 ---
set subtest1 "TEST 1: init hook - set a C global"
foreach runtime [get_runtime_list] {
if {$runtime eq ""} {
set runtime "kernel"
}
set test_name "$test: $subtest1 ($runtime)"
set stp_opts "-g"
set cmd "stap $stp_opts --runtime=$runtime '$srcdir/$subdir/${test}_1.stp'"
set exit_code [run_cmd_2way $cmd out stderr]
set exp_out "res: 2\n"
is "${test_name}: stdout" $out $exp_out
is "${test_name}: exit code" $exit_code 0
if {$stderr ne ""} {
send_log "stderr:\n$stderr"
}
}
# --- TEST 2 ---
set subtest2 "TEST 2: init & exit hook"
foreach runtime [get_runtime_list] {
if {$runtime eq ""} {
set runtime "kernel"
}
set test_name "$test: $subtest2 ($runtime)"
set stp_opts "-g -DDEBUG_MEM"
set cmd "stap $stp_opts --runtime=$runtime '$srcdir/$subdir/${test}_2.stp'"
set exit_code [run_cmd_2way $cmd out stderr]
set exp_out "res: 17\n"
is "${test_name}: stdout" $out $exp_out
is "${test_name}: exit code" $exit_code 0
if {$stderr ne ""} {
send_log "stderr:\n$stderr"
}
}
# --- TEST 3 ---
set subtest3 "TEST 3: failed init hook"
foreach runtime [get_runtime_list] {
if {$runtime eq ""} {
set runtime "kernel"
}
set test_name "$test: $subtest3 ($runtime)"
set stp_opts "-g"
set cmd "stap $stp_opts --runtime=$runtime '$srcdir/$subdir/${test}_3.stp'"
set exit_code [run_cmd_2way $cmd out stderr]
set exp_out ""
is "${test_name}: stdout" $out $exp_out
isnt "${test_name}: exit code" $exit_code 0
set stderr_pat "^ERROR: Failed to run STAP_MODULE_INIT_HOOK \\(-12\\)\$"
like "${test_name}: stderr" $stderr $stderr_pat "-lineanchor"
}
|