e54086f9e6260f423df3bd57f71e5caf1e28b4d2
[platform/upstream/ltrace.git] / testsuite / ltrace.main / parameters.exp
1 # This file was written by Steve Fink <sphink@gmail.com>.
2 # Based on main.c by Yao Qi <qiyao@cn.ibm.com>.
3
4 set testfile "parameters"
5 set srcfile ${testfile}.c
6 set binfile ${testfile}
7 set libfile "parameters-lib"
8 set libsrc $srcdir/$subdir/$libfile.c
9 set lib_sl $objdir/$subdir/lib$testfile.so
10
11
12 if [get_compiler_info $binfile] {
13   return -1
14 }
15
16 verbose "compiling source file now....."
17 if { [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.
23 ltrace_options "-l" "libparameters.so" "-F" "$srcdir/$subdir/parameters.conf"
24
25 # Run PUT for ltarce.
26 set exec_output [ltrace_runtest $objdir/$subdir $objdir/$subdir/$binfile]
27
28 # Check the output of this program.
29 verbose "ltrace runtest output: $exec_output\n"
30 if [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 set xfail_spec {"arm*-*" }
39 set xfail_spec_arm {"arm*-*"}
40
41 # Verify the output
42 set pattern "func_intptr(17)"
43 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
44 set pattern "func_intptr_ret(42)"
45 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
46 set pattern "func_strlen(\\\"Hello world\\\") *= *11"
47 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
48 set pattern "func_arg0(\\\"Hello another world!\\\") *= *20"
49 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
50 set pattern "func_strfixed(\\\"Hell\\\")"
51 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
52 set pattern "func_ppp(80)"
53 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
54 set pattern "func_stringp(\\\"Dude\\\")"
55 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
56 set pattern "func_string(\\\"zero\\\")"
57 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
58 set pattern "func_enum(BLUE)"
59 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
60 set pattern "func_short(-8, -9)"
61 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
62 set pattern "func_ushort(33, 34)"
63 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
64 set pattern "func_float(3.40*, -3.40*).*= 3.40*"
65 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
66 eval "setup_xfail $xfail_spec"
67 set pattern "func_double(3.40*, -3.40*).*= -3.40*"
68 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
69 set pattern "func_typedef(BLUE)"
70 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
71 set pattern "func_arrayi(. 10, 11, 12, 13\\.\\.\\. ., 8)"
72 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
73 set pattern "func_arrayi(. 10, 11 ., 2)"
74 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
75 set pattern "func_arrayf(. 10.10*, 11.10*, 12.10*, 13.10*\\.\\.\\. ., 8)"
76 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
77 set pattern "func_arrayf(. 10.10*, 11.10* ., 2)"
78 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
79 set pattern "exited (status 0)"
80 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
81 set pattern "func_struct({ 89, 2, 3, . { 1, 10 }, { 3, 30 } ., . { 4, 40 }, { 5, 50 }, { 6, 60 } ., \\\"123\\\" })"
82 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
83 set pattern "func_call( <unfinished ...>"
84 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
85 set pattern "func_work(\\\"x\\\")"
86 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
87 set pattern "func_struct_2(17, { \\\"ABCDE\\\\\\\\0\\\", 0.250* }, 0.50*).*= { 0.250*, 'B', 'C' }"
88 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
89 eval "setup_xfail $xfail_spec_arm"
90 set pattern "<... func_call resumed> \\\"x\\\", \\\"y\\\")"
91 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
92
93 set pattern "func_struct_large({ 1, 2, 3, 4 }, { 5, 6, 7, 8 }).*= { 6, 8, 10, 12 }"
94 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
95
96 set pattern "func_struct_large2({ '0', '1', 3, 4 }, { '2', '3', 7, 8 }).*= { 'b', 'd', 10, 12 }"
97 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
98
99 set pattern "func_struct_large3({ 3, 4, '0', '1' }, { 7, 8, '2', '3' }).*= { 10, 12, 'b', 'd' }"
100 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
101
102 set pattern "func_many_args(1, 2, 3, 4.00*, '5', 6, 7.00*, '8', 9, 10.00*, 11, 12.00*, 'A', 14, 15, 16, 'B', 18.00*, 19.00*, 20.00*, 21, 22.00*, 23.00*, 24.00*, 25.00*)"
103 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
104
105 set pattern "func_printf(\\\"sotnuh %d %ld %g %c.n\\\", 5, 6, 1.500*, 'X')"
106 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
107
108 set pattern "func_printf(\\\"sotnuh1 %d %ld %hd.n\\\", 5, 6, 7)"
109 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
110
111 set pattern "func_printf(\\\"sotnuh2 %s %10s %10s.n\\\", \\\"a string\\\", \\\"a trimmed \\\", \\\"short\\\")"
112 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
113
114 set pattern "func_printf(\\\"sotnuh3 %.s.n\\\", 4, \\\"a tr\\\")"
115 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
116
117 set pattern "func_printf(\\\"many_args%d %d %ld %g %c %d %g .*, 1, 2, 3, 4.00*, '5', 6, 7.00*, '8', 9, 10.00*, 11, 12.00*, 'A', 14, 15, 16, 'B', 18.00*, 19.00*, 20.00*, 21, 22.00*, 23.00*, 24.00*, 25.00*)"
118 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
119
120 set pattern "func_sprintf(nil, \\\"test %d %d %d %d.n\\\", 1, 2, 3, 4)"
121 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
122
123 set pattern "func_lens(026, 027, 0x18, 0x19)"
124 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
125
126 set pattern "func_bool(1, true).*= false"
127 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
128
129 set pattern "func_bool(2, false).*= true"
130 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
131
132 set pattern "func_hide(2, 5, 7)"
133 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
134
135 set pattern "func_hide_struct({ 2, 5, 7 })"
136 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
137
138 set pattern "func_short_enums(. A, B, A, A .).*= . A, B, A, A ."
139 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
140
141 set pattern "func_negative_enum(A, A, A, A, A, A).*= A"
142 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
143
144 set pattern "func_charp_string(\\\"null-terminated string\\\")"
145 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
146
147 set pattern "func_dbl_eqv({ 2.500* }, { { 1.50* } }, { { { 0.50* } } }, { { { { -0.50* } } } }).*= { 4.00* }"
148 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
149
150 set pattern "func_flt_eqv({ 2.500* }, { { 1.50* } }, { { { 0.50* } } }, { { { { -0.50* } } } }).*= { 4.00* }"
151 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
152
153 set pattern "func_struct_empty({ *}).*= { *}"
154 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
155
156 set pattern "func_struct_size1({ '5' }).*= { '5' }"
157 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
158
159 set pattern "func_struct_size2({ 5 }).*= { 5 }"
160 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
161
162 set pattern "func_struct_size4({ 5 }).*= { 5 }"
163 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
164
165 set pattern "func_struct_size8({ 5, 6 }).*= { 5, 6 }"
166 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
167
168 set pattern "func_hfa_f2({ 1.000*, { 2.000* } }).*= { 1.000*, { 2.000* } }"
169 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
170
171 set pattern "func_hfa_f3({ 3.000*, { 1.000*, { 2.000* } } }).*= { 3.000*, { 1.000*, { 2.000* } } }"
172 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
173
174 set pattern "func_hfa_f4({ 4.000*, { 3.000*, { 1.000*, { 2.000* } } } }).*= { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } }"
175 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
176
177 set pattern "func_hfa_f5({ 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } }).*= { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } }"
178 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
179
180 set pattern "func_hfa_f6({ 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } }).*= { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } }"
181 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
182
183 set pattern "func_hfa_f7({ 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } }).*= { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } }"
184 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
185
186 set pattern "func_hfa_f8({ 8.000*, { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } } }).*= { 8.000*, { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } } }"
187 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
188
189 set pattern "func_hfa_f9({ 9.000*, { 8.000*, { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } } } }).*= { 9.000*, { 8.000*, { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } } } }"
190 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
191
192 set pattern "func_hfa_f10({ 10.000*, { 9.000*, { 8.000*, { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } } } } }).*= { 10.000*, { 9.000*, { 8.000*, { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } } } } }"
193 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
194
195 set pattern "func_hfa_f11({ 11.000*, { 10.000*, { 9.000*, { 8.000*, { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } } } } } }).*= { 11.000*, { 10.000*, { 9.000*, { 8.000*, { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } } } } } }"
196 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
197
198 set pattern "func_hfa_f12({ 12.000*, { 11.000*, { 10.000*, { 9.000*, { 8.000*, { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } } } } } } }).*= { 12.000*, { 11.000*, { 10.000*, { 9.000*, { 8.000*, { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } } } } } } }"
199 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
200
201 set pattern "func_hfa_d2({ 1.000*, { 2.000* } }).*= { 1.000*, { 2.000* } }"
202 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
203
204 set pattern "func_hfa_d3({ 3.000*, { 1.000*, { 2.000* } } }).*= { 3.000*, { 1.000*, { 2.000* } } }"
205 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
206
207 set pattern "func_hfa_d4({ 4.000*, { 3.000*, { 1.000*, { 2.000* } } } }).*= { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } }"
208 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
209
210 set pattern "func_hfa_d5({ 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } }).*= { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } }"
211 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
212
213 set pattern "func_hfa_d6({ 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } }).*= { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } }"
214 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
215
216 set pattern "func_hfa_d7({ 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } }).*= { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } }"
217 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
218
219 set pattern "func_hfa_d8({ 8.000*, { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } } }).*= { 8.000*, { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } } }"
220 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
221
222 set pattern "func_hfa_d9({ 9.000*, { 8.000*, { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } } } }).*= { 9.000*, { 8.000*, { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } } } }"
223 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
224
225 set pattern "func_hfa_d10({ 10.000*, { 9.000*, { 8.000*, { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } } } } }).*= { 10.000*, { 9.000*, { 8.000*, { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } } } } }"
226 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
227
228 set pattern "func_hfa_d11({ 11.000*, { 10.000*, { 9.000*, { 8.000*, { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } } } } } }).*= { 11.000*, { 10.000*, { 9.000*, { 8.000*, { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } } } } } }"
229 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
230
231 set pattern "func_hfa_d12({ 12.000*, { 11.000*, { 10.000*, { 9.000*, { 8.000*, { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } } } } } } }).*= { 12.000*, { 11.000*, { 10.000*, { 9.000*, { 8.000*, { 7.000*, { 6.000*, { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } } } } } } } } }"
232 ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1