parameters.exp revision 3a8a91ca57f66d664b3fbd19882e6d163c7ad496
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" "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 38set xfail_spec {"arm*-*" } 39set xfail_spec_arm {"arm*-*"} 40 41# Verify the output 42set pattern "func_intptr(17)" 43ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 44set pattern "func_intptr_ret(42)" 45ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 46set pattern "func_strlen(\\\"Hello world\\\") *= *11" 47ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 48set pattern "func_arg0(\\\"Hello another world!\\\") *= *20" 49ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 50set pattern "func_strfixed(\\\"Hell\\\")" 51ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 52set pattern "func_ppp(80)" 53ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 54set pattern "func_stringp(\\\"Dude\\\")" 55ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 56set pattern "func_string(\\\"zero\\\")" 57ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 58set pattern "func_enum(BLUE)" 59ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 60set pattern "func_short(-8, -9)" 61ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 62set pattern "func_ushort(33, 34)" 63ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 64set pattern "func_float(3.40*, -3.40*).*= 3.40*" 65ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 66eval "setup_xfail $xfail_spec" 67set pattern "func_double(3.40*, -3.40*).*= -3.40*" 68ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 69set pattern "func_typedef(BLUE)" 70ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 71set pattern "func_arrayi(. 10, 11, 12, 13\\.\\.\\. ., 8)" 72ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 73set pattern "func_arrayi(. 10, 11 ., 2)" 74ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 75set pattern "func_arrayf(. 10.10*, 11.10*, 12.10*, 13.10*\\.\\.\\. ., 8)" 76ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 77set pattern "func_arrayf(. 10.10*, 11.10* ., 2)" 78ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 79set pattern "exited (status 0)" 80ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 81set pattern "func_struct({ 89, 2, 3, . { 1, 10 }, { 3, 30 } ., . { 4, 40 }, { 5, 50 }, { 6, 60 } ., \\\"123\\\" })" 82ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 83set pattern "func_call( <unfinished ...>" 84ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 85set pattern "func_work(\\\"x\\\")" 86ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 87set pattern "func_struct_2(17, { \\\"ABCDE\\\\\\\\0\\\", 0.250* }, 0.50*).*= { 0.250*, 'B', 'C' }" 88ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 89eval "setup_xfail $xfail_spec_arm" 90set pattern "<... func_call resumed> \\\"x\\\", \\\"y\\\")" 91ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 92 93set pattern "func_struct_large({ 1, 2, 3, 4 }, { 5, 6, 7, 8 }).*= { 6, 8, 10, 12 }" 94ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 95 96set pattern "func_struct_large2({ '0', '1', 3, 4 }, { '2', '3', 7, 8 }).*= { 'b', 'd', 10, 12 }" 97ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 98 99set pattern "func_struct_large3({ 3, 4, '0', '1' }, { 7, 8, '2', '3' }).*= { 10, 12, 'b', 'd' }" 100ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 101 102set 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*)" 103ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 104 105set pattern "func_printf(\\\"sotnuh %d %ld %g %c.n\\\", 5, 6, 1.500*, 'X')" 106ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 107 108set pattern "func_printf(\\\"sotnuh1 %d %ld %hd.n\\\", 5, 6, 7)" 109ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 110 111set pattern "func_printf(\\\"sotnuh2 %s %10s %10s.n\\\", \\\"a string\\\", \\\"a trimmed \\\", \\\"short\\\")" 112ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 113 114set pattern "func_printf(\\\"sotnuh3 %.s.n\\\", 4, \\\"a tr\\\")" 115ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 116 117set 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*)" 118ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 119 120set pattern "func_sprintf(\\\"\\\", \\\"test %d %d %d %d.n\\\", 1, 2, 3, 4)" 121ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 122 123set pattern "func_lens(026, 027, 0x18, 0x19)" 124ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 125 126set pattern "func_bool(1, true).*= false" 127ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 128 129set pattern "func_bool(2, false).*= true" 130ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 131 132set pattern "func_hide(1, 4, 6)" 133ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 134 135set pattern "func_short_enums(. A, B, A, A .).*= . A, B, A, A ." 136ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 137 138set pattern "func_negative_enum(A, A, A, A, A, A).*= A" 139ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 140 141set pattern "func_charp_string(\\\"null-terminated string\\\")" 142ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 143 144set pattern "func_dbl_eqv({ 2.500* }, { { 1.50* } }, { { { 0.50* } } }, { { { { -0.50* } } } }).*= { 4.00* }" 145ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 146 147set pattern "func_flt_eqv({ 2.500* }, { { 1.50* } }, { { { 0.50* } } }, { { { { -0.50* } } } }).*= { 4.00* }" 148ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 149 150set pattern "func_struct_empty({ *}).*= { *}" 151ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 152 153set pattern "func_struct_size1({ '5' }).*= { '5' }" 154ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 155 156set pattern "func_struct_size2({ 5 }).*= { 5 }" 157ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 158 159set pattern "func_struct_size4({ 5 }).*= { 5 }" 160ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 161 162set pattern "func_struct_size8({ 5, 6 }).*= { 5, 6 }" 163ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 164 165set pattern "func_hfa_f2({ 1.000*, { 2.000* } }).*= { 1.000*, { 2.000* } }" 166ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 167 168set pattern "func_hfa_f3({ 3.000*, { 1.000*, { 2.000* } } }).*= { 3.000*, { 1.000*, { 2.000* } } }" 169ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 170 171set pattern "func_hfa_f4({ 4.000*, { 3.000*, { 1.000*, { 2.000* } } } }).*= { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } }" 172ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 173 174set pattern "func_hfa_f5({ 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } }).*= { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } }" 175ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 176 177set 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* } } } } } }" 178ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 179 180set 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* } } } } } } }" 181ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 182 183set 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* } } } } } } } }" 184ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 185 186set 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* } } } } } } } } }" 187ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 188 189set 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* } } } } } } } } } }" 190ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 191 192set 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* } } } } } } } } } } }" 193ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 194 195set 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* } } } } } } } } } } } }" 196ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 197 198set pattern "func_hfa_d2({ 1.000*, { 2.000* } }).*= { 1.000*, { 2.000* } }" 199ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 200 201set pattern "func_hfa_d3({ 3.000*, { 1.000*, { 2.000* } } }).*= { 3.000*, { 1.000*, { 2.000* } } }" 202ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 203 204set pattern "func_hfa_d4({ 4.000*, { 3.000*, { 1.000*, { 2.000* } } } }).*= { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } }" 205ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 206 207set pattern "func_hfa_d5({ 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } }).*= { 5.000*, { 4.000*, { 3.000*, { 1.000*, { 2.000* } } } } }" 208ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 209 210set 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* } } } } } }" 211ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 212 213set 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* } } } } } } }" 214ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 215 216set 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* } } } } } } } }" 217ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 218 219set 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* } } } } } } } } }" 220ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 221 222set 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* } } } } } } } } } }" 223ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 224 225set 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* } } } } } } } } } } }" 226ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 227 228set 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* } } } } } } } } } } } }" 229ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 230