branch_func.exp revision 31b2f9f7296e52aff489138c78be2f8cf9140bbc
1ba7d94b8f3c41fd5b933b185e7463a56589e04d2Jim Miller# This file is part of ltrace. 2ba7d94b8f3c41fd5b933b185e7463a56589e04d2Jim Miller# Copyright (C) 2012 Petr Machata, Red Hat Inc. 3ba7d94b8f3c41fd5b933b185e7463a56589e04d2Jim Miller# 4ba7d94b8f3c41fd5b933b185e7463a56589e04d2Jim Miller# This program is free software; you can redistribute it and/or 5ba7d94b8f3c41fd5b933b185e7463a56589e04d2Jim Miller# modify it under the terms of the GNU General Public License as 6ba7d94b8f3c41fd5b933b185e7463a56589e04d2Jim Miller# published by the Free Software Foundation; either version 2 of the 7ba7d94b8f3c41fd5b933b185e7463a56589e04d2Jim Miller# License, or (at your option) any later version. 8ba7d94b8f3c41fd5b933b185e7463a56589e04d2Jim Miller# 9ba7d94b8f3c41fd5b933b185e7463a56589e04d2Jim Miller# This program is distributed in the hope that it will be useful, but 10ba7d94b8f3c41fd5b933b185e7463a56589e04d2Jim Miller# WITHOUT ANY WARRANTY; without even the implied warranty of 11ba7d94b8f3c41fd5b933b185e7463a56589e04d2Jim Miller# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 12ba7d94b8f3c41fd5b933b185e7463a56589e04d2Jim Miller# General Public License for more details. 13ba7d94b8f3c41fd5b933b185e7463a56589e04d2Jim Miller# 14ba7d94b8f3c41fd5b933b185e7463a56589e04d2Jim Miller# You should have received a copy of the GNU General Public License 15ba7d94b8f3c41fd5b933b185e7463a56589e04d2Jim Miller# along with this program; if not, write to the Free Software 16ba7d94b8f3c41fd5b933b185e7463a56589e04d2Jim Miller# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 173eb4971b679464e206cb666de1cf0e5a538c8d7dJim Miller# 02110-1301 USA 183eb4971b679464e206cb666de1cf0e5a538c8d7dJim Miller 193eb4971b679464e206cb666de1cf0e5a538c8d7dJim Millerset testfile "branch_func" 205e612cf07872dc0989a4b9f09e2a38a2ee12186dJim Millerset srcfile ${testfile}.c 213eb4971b679464e206cb666de1cf0e5a538c8d7dJim Millerset binfile ${testfile} 225e612cf07872dc0989a4b9f09e2a38a2ee12186dJim Miller 233eb4971b679464e206cb666de1cf0e5a538c8d7dJim Millerif [get_compiler_info $binfile] { 243eb4971b679464e206cb666de1cf0e5a538c8d7dJim Miller return -1 253eb4971b679464e206cb666de1cf0e5a538c8d7dJim Miller} 263eb4971b679464e206cb666de1cf0e5a538c8d7dJim Miller 273eb4971b679464e206cb666de1cf0e5a538c8d7dJim Millerverbose "compiling source file now....." 28c42d33004dace5155b36a5c2e9468dbbe343af66Adrian Roosif { [ltrace_compile $srcdir/$subdir/$srcfile $objdir/$subdir/$binfile executable {debug} ] != "" } { 293eb4971b679464e206cb666de1cf0e5a538c8d7dJim Miller send_user "Testcase compile failed, so all tests in this file will automatically fail\n." 303eb4971b679464e206cb666de1cf0e5a538c8d7dJim Miller} 313eb4971b679464e206cb666de1cf0e5a538c8d7dJim Miller 325e612cf07872dc0989a4b9f09e2a38a2ee12186dJim Miller# set options for ltrace. 335e612cf07872dc0989a4b9f09e2a38a2ee12186dJim Millerltrace_options "-x" "func1" "-x" "func2" 345e612cf07872dc0989a4b9f09e2a38a2ee12186dJim Miller 355e612cf07872dc0989a4b9f09e2a38a2ee12186dJim Miller# Run PUT for ltarce. 365e612cf07872dc0989a4b9f09e2a38a2ee12186dJim Millerset exec_output [ltrace_runtest $objdir/$subdir $objdir/$subdir/$binfile] 375e612cf07872dc0989a4b9f09e2a38a2ee12186dJim Miller 385e612cf07872dc0989a4b9f09e2a38a2ee12186dJim Miller# Check the output of this program. 395e612cf07872dc0989a4b9f09e2a38a2ee12186dJim Millerverbose "ltrace runtest output: $exec_output\n" 405e612cf07872dc0989a4b9f09e2a38a2ee12186dJim Millerif [regexp {ELF from incompatible architecture} $exec_output] { 415e612cf07872dc0989a4b9f09e2a38a2ee12186dJim Miller fail "32-bit ltrace can not perform on 64-bit PUTs and rebuild ltrace in 64 bit mode!" 423eb4971b679464e206cb666de1cf0e5a538c8d7dJim Miller return 43a0be6d53a823f8115d3863773398d640ec2a8c44Jorim Jaggi} elseif [ regexp {Couldn't get .hash data} $exec_output ] { 443eb4971b679464e206cb666de1cf0e5a538c8d7dJim Miller fail "Couldn't get .hash data!" 453eb4971b679464e206cb666de1cf0e5a538c8d7dJim Miller return 463eb4971b679464e206cb666de1cf0e5a538c8d7dJim Miller} 473eb4971b679464e206cb666de1cf0e5a538c8d7dJim Miller 485e612cf07872dc0989a4b9f09e2a38a2ee12186dJim Millerset pattern "func1(.*unfinished" 495e612cf07872dc0989a4b9f09e2a38a2ee12186dJim Millerltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 100 505e612cf07872dc0989a4b9f09e2a38a2ee12186dJim Millerset pattern "func2(.*)" 515e612cf07872dc0989a4b9f09e2a38a2ee12186dJim Millerltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 100 525e612cf07872dc0989a4b9f09e2a38a2ee12186dJim Millerset pattern "func1.resumed" 535e612cf07872dc0989a4b9f09e2a38a2ee12186dJim Millerltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 100 545e612cf07872dc0989a4b9f09e2a38a2ee12186dJim Miller