parameters.exp revision 280f829ca87ff6b6c3a242a97fcef01d4488d2c8
1# This file was written by Steve Fink <sphink@gmail.com>.
2# Based on main.c by Yao Qi <qiyao@cn.ibm.com>.
3
4set testfile "parameters"
5set srcfile ${testfile}.c
6set binfile ${testfile}
7set libfile "parameters-lib"
8set libsrc $srcdir/$subdir/$libfile.c
9set lib_sl $objdir/$subdir/lib$testfile.so
10
11
12if [get_compiler_info $binfile] {
13  return -1
14}
15
16verbose "compiling source file now....."
17if { [ltrace_compile_shlib $libsrc $lib_sl debug ] != ""
18  || [ltrace_compile $srcdir/$subdir/$srcfile $objdir/$subdir/$binfile executable [list debug shlib=$lib_sl] ] != ""} {
19  send_user "Testcase compile failed, so all tests in this file will automatically fail.\n"
20}
21
22# set options for ltrace.
23ltrace_options "-l" "$objdir/$subdir/libparameters.so" "-F" "$srcdir/$subdir/parameters.conf"
24
25# Run PUT for ltarce.
26set exec_output [ltrace_runtest $objdir/$subdir $objdir/$subdir/$binfile]
27
28# Check the output of this program.
29verbose "ltrace runtest output: $exec_output\n"
30if [regexp {ELF from incompatible architecture} $exec_output] {
31	fail "32-bit ltrace can not perform on 64-bit PUTs and rebuild ltrace in 64 bit mode!"
32	return
33} elseif [ regexp {Couldn't get .hash data} $exec_output ] {
34	fail "Couldn't get .hash data!"
35	return
36}
37
38# Verify the output
39set pattern "func_intptr(17)"
40ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
41set pattern "func_intptr_ret(42)"
42ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
43set pattern "func_strlen(\\\"Hello world\\\") *= *11"
44ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
45set pattern "func_strfixed(\\\"Hell\\\")"
46ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
47set pattern "func_ppp(80)"
48ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
49set pattern "func_stringp(\\\"Dude\\\")"
50ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
51set pattern "func_enum(BLUE)"
52ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
53set pattern "func_short(-8, -9)"
54ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
55set pattern "func_ushort(33, 34)"
56ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
57set pattern "func_float(3.40*, -3.40*).*= 3.40*"
58ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
59set pattern "func_double(3.40*, -3.40*).*= -3.40*"
60ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
61set pattern "func_typedef(BLUE)"
62ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
63set pattern "func_arrayi(. 10, 11, 12, 13\\.\\.\\. ., )"
64ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
65set pattern "func_arrayi(. 10, 11 ., )"
66ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
67set pattern "func_arrayf(. 10.10*, 11.10*, 12.10*, 13.10*\\.\\.\\. ., )"
68ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
69set pattern "func_arrayf(. 10.10*, 11.10* ., )"
70ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
71set pattern "exited (status 0)"
72ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
73set pattern "func_struct({ 89, 2, 3, . { 1, 10 }, { 3, 30 } ., . { 4, 40 }, { 5, 50 }, { 6, 60 } ., \\\"123\\\" })"
74ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
75set pattern "func_call( <unfinished ...>"
76ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
77set pattern "func_work(\\\"x\\\")"
78ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
79set pattern "<... func_call resumed> \\\"x\\\", \\\"y\\\")"
80ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
81