parameters.exp revision e22411dd33d2d55fd5c6510390954f13fd502d3a
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 $srcdir/$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 $srcdir/$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" "$srcdir/$subdir/libparameters.so" "-F" "$srcdir/$subdir/parameters.conf"
24
25# Run PUT for ltarce.
26set exec_output [ltrace_runtest $srcdir/$subdir $srcdir/$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_ignore(1, *, *3)"
40ltrace_verify_output ${srcdir}/${subdir}/${testfile}.ltrace $pattern 1
41set pattern "func_intptr(17)"
42ltrace_verify_output ${srcdir}/${subdir}/${testfile}.ltrace $pattern 1
43set pattern "func_intptr_ret(42)"
44ltrace_verify_output ${srcdir}/${subdir}/${testfile}.ltrace $pattern 1
45set pattern "func_strlen(\\\"Hello world\\\") *= *11"
46ltrace_verify_output ${srcdir}/${subdir}/${testfile}.ltrace $pattern 1
47set pattern "func_strfixed(\\\"Hell\\\")"
48ltrace_verify_output ${srcdir}/${subdir}/${testfile}.ltrace $pattern 1
49set pattern "func_ppp(80)"
50ltrace_verify_output ${srcdir}/${subdir}/${testfile}.ltrace $pattern 1
51set pattern "func_stringp(\\\"Dude\\\")"
52ltrace_verify_output ${srcdir}/${subdir}/${testfile}.ltrace $pattern 1
53set pattern "func_enum(BLUE)"
54ltrace_verify_output ${srcdir}/${subdir}/${testfile}.ltrace $pattern 1
55set pattern "func_short(-8, -9)"
56ltrace_verify_output ${srcdir}/${subdir}/${testfile}.ltrace $pattern 1
57set pattern "func_ushort(33, 34)"
58ltrace_verify_output ${srcdir}/${subdir}/${testfile}.ltrace $pattern 1
59set pattern "func_float(3.40*, -3.40*)"
60ltrace_verify_output ${srcdir}/${subdir}/${testfile}.ltrace $pattern 1
61set pattern "func_typedef(BLUE)"
62ltrace_verify_output ${srcdir}/${subdir}/${testfile}.ltrace $pattern 1
63set pattern "exited (status 0)"
64ltrace_verify_output ${srcdir}/${subdir}/${testfile}.ltrace $pattern 1
65