When comparing gcc testsuite results from two (slightly) different source tree with dg-cmp-results.sh, I ran into an old issue: some testsuites log absolute paths for either sources or executables, rendering comparison difficult. The libjava side of this problem was logged as PR libgcj/21164, but the issue also occurs in lto.exp and compat.exp.
This patch fixes this. Bootstrapped without regressions on i386-pc-solaris2.11 and comparing gcc.sum, g++.sum and libjava.sum. Will install shortly unless someone objects. Rainer 2011-04-09 Rainer Orth <r...@cebitec.uni-bielefeld.de> libjava: PR testsuite/21164 * testsuite/lib/libjava.exp: Load dg.exp. * testsuite/libjava.jar/jar.exp (gcj_jar_interpret): Strip srcdir from jarfile. Use result for messages. * testsuite/libjava.loader/loader.exp (gcj_loader_test_one): Pass errname to libjava_invoke, fix testname. gcc: PR testsuite/21164 * lib/compat.exp (compat-execute): Declare unsupported after stripping path from src1. * lib/lto.exp (lto-execute): Likewise. diff --git a/gcc/testsuite/lib/compat.exp b/gcc/testsuite/lib/compat.exp --- a/gcc/testsuite/lib/compat.exp +++ b/gcc/testsuite/lib/compat.exp @@ -1,4 +1,4 @@ -# Copyright (C) 2002, 2003, 2004, 2005, 2007, 2008 +# Copyright (C) 2002, 2003, 2004, 2005, 2007, 2008, 2011 # Free Software Foundation, Inc. # This program is free software; you can redistribute it and/or modify @@ -260,13 +260,6 @@ proc compat-execute { src1 sid use_alt } set dg-do-what [list ${dg-do-what-default} "" P] set extra_flags_1 [compat-get-options-main $src1] - # Check whether this test is supported for this target. - if { [lindex ${dg-do-what} 1 ] == "N" } { - unsupported "$src1" - verbose "$src1 not supported on this target, skipping it" 3 - return - } - # Set up the names of the other source files. set dir [file dirname $src1] set ext [file extension $src1] @@ -314,10 +307,6 @@ proc compat-execute { src1 sid use_alt } set testcase [string range "$testcase" [string length "$tmpdir/"] end] set testcase "tmpdir-$testcase" } - regsub "_main.*" $testcase "" testcase - # Set up the base name of executable files so they'll be unique. - regsub -all "\[./\]" $testcase "-" execbase - # If we couldn't rip $srcdir out of `src1' then just do the best we can. # The point is to reduce the unnecessary noise in the logs. Don't strip # out too much because different testcases with the same name can confuse @@ -326,6 +315,17 @@ proc compat-execute { src1 sid use_alt } set testcase "[file tail [file dirname $src1]]/[file tail $src1]" } + # Check whether this test is supported for this target. + if { [lindex ${dg-do-what} 1 ] == "N" } { + unsupported "$testcase" + verbose "$testcase not supported on this target, skipping it" 3 + return + } + + regsub "_main.*" $testcase "" testcase + # Set up the base name of executable files so they'll be unique. + regsub -all "\[./\]" $testcase "-" execbase + # Loop through all of the option lists used for this test. set count 0 diff --git a/gcc/testsuite/lib/lto.exp b/gcc/testsuite/lib/lto.exp --- a/gcc/testsuite/lib/lto.exp +++ b/gcc/testsuite/lib/lto.exp @@ -410,13 +410,6 @@ proc lto-execute { src1 sid } { set lto_option_list $LTO_OPTIONS } - # Check whether this test is supported for this target. - if { [lindex ${dg-do-what} 1 ] == "N" } { - unsupported "$src1" - verbose "$src1 not supported on this target, skipping it" 3 - return - } - # Set up the names of the other source files. set dir [file dirname $src1] set base [file rootname $src1] @@ -470,11 +463,6 @@ proc lto-execute { src1 sid } { set testcase [string range "$testcase" [string length "$tmpdir/"] end] set testcase "tmpdir-$testcase" } - regsub "_0.*" $testcase "" testcase - - # Set up the base name of executable files so they'll be unique. - regsub -all "\[./\]" $testcase "-" execbase - # If we couldn't rip $srcdir out of `src1' then just do the best we can. # The point is to reduce the unnecessary noise in the logs. Don't strip # out too much because different testcases with the same name can confuse @@ -483,6 +471,18 @@ proc lto-execute { src1 sid } { set testcase "[file tail [file dirname $src1]]/[file tail $src1]" } + # Check whether this test is supported for this target. + if { [lindex ${dg-do-what} 1 ] == "N" } { + unsupported "$testcase" + verbose "$testcase not supported on this target, skipping it" 3 + return + } + + regsub "_0.*" $testcase "" testcase + + # Set up the base name of executable files so they'll be unique. + regsub -all "\[./\]" $testcase "-" execbase + # Loop through all of the option lists used for this test. set count 0 foreach option $lto_option_list { diff --git a/libjava/testsuite/lib/libjava.exp b/libjava/testsuite/lib/libjava.exp --- a/libjava/testsuite/lib/libjava.exp +++ b/libjava/testsuite/lib/libjava.exp @@ -1,4 +1,5 @@ -# Copyright (C) 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2006, 2007 Free Software Foundation +# Copyright (C) 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2006, 2007, 2011 +# Free Software Foundation proc load_gcc_lib { filename } { global srcdir @@ -6,6 +7,7 @@ proc load_gcc_lib { filename } { } load_lib libgloss.exp +load_lib dg.exp load_gcc_lib target-libpath.exp # GCJ_UNDER_TEST is the compiler under test. diff --git a/libjava/testsuite/libjava.jar/jar.exp b/libjava/testsuite/libjava.jar/jar.exp --- a/libjava/testsuite/libjava.jar/jar.exp +++ b/libjava/testsuite/libjava.jar/jar.exp @@ -20,17 +20,18 @@ proc gcj_jar_interpret {jarfile} { global INTERPRETER srcdir set gij [libjava_find_gij] + set errname [dg-trim-dirname $srcdir $jarfile] # libjava_find_gij will return "" if it couldn't find the # program; in this case we want to skip the test. if {$INTERPRETER != "yes" || $gij == ""} { - untested "$jarfile execution - gij test" - untested "$jarfile output - gij test" + untested "$errname execution - gij test" + untested "$errname output - gij test" return } set opts(_) {} set out [file rootname $jarfile].out - libjava_invoke $jarfile "gij test" opts $gij {} $out \ + libjava_invoke $errname "gij test" opts $gij {} $out \ "" -jar $jarfile } diff --git a/libjava/testsuite/libjava.loader/loader.exp b/libjava/testsuite/libjava.loader/loader.exp --- a/libjava/testsuite/libjava.loader/loader.exp +++ b/libjava/testsuite/libjava.loader/loader.exp @@ -34,7 +34,7 @@ proc gcj_loader_test_one {srcfile} { } pass "$errname compilation from source" - libjava_invoke $executable $executable "" $executable "" $resfile "" + libjava_invoke $errname "source compiled test" "" $executable "" $resfile "" return 1 } -- ----------------------------------------------------------------------------- Rainer Orth, Center for Biotechnology, Bielefeld University