summaryrefslogtreecommitdiff
path: root/contrib
diff options
context:
space:
mode:
authorrwild <rwild@138bc75d-0d04-0410-961f-82ee72b054a4>2010-10-11 18:04:01 +0000
committerrwild <rwild@138bc75d-0d04-0410-961f-82ee72b054a4>2010-10-11 18:04:01 +0000
commit0d387a7b6e0e6bc5cab794149a383abbe7333a5e (patch)
treeaa10a3b2cc364bf1afe43d3fb29c7c9a98071833 /contrib
parent679b73a3fd5dedcb18c4f485401b790eca53eafd (diff)
downloadgcc-0d387a7b6e0e6bc5cab794149a383abbe7333a5e.tar.gz
New contrib/test_recheck script to rerun unsuccessful tests.
contrib/: * test_recheck: New script. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@165324 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'contrib')
-rw-r--r--contrib/ChangeLog4
-rwxr-xr-xcontrib/test_recheck98
2 files changed, 102 insertions, 0 deletions
diff --git a/contrib/ChangeLog b/contrib/ChangeLog
index b98ef7bc989..c7152afe169 100644
--- a/contrib/ChangeLog
+++ b/contrib/ChangeLog
@@ -1,3 +1,7 @@
+2010-10-11 Ralf Wildenhues <Ralf.Wildenhues@gmx.de>
+
+ * test_recheck: New script.
+
2010-08-22 Ralf Wildenhues <Ralf.Wildenhues@gmx.de>
* texi2pod.pl: Replace @@ before @{ and @}, for @samp{@@}.
diff --git a/contrib/test_recheck b/contrib/test_recheck
new file mode 100755
index 00000000000..193cd3df2a3
--- /dev/null
+++ b/contrib/test_recheck
@@ -0,0 +1,98 @@
+#! /bin/sh
+
+# (C) 2010 Free Software Foundation
+# Written by Ralf Wildenhues <Ralf.Wildenhues@gmx.de>.
+
+# This script is Free Software, and it can be copied, distributed and
+# modified as defined in the GNU General Public License. A copy of
+# its license can be downloaded from http://www.gnu.org/copyleft/gpl.html
+
+PROGNAME=test_recheck
+
+usage ()
+{
+ cat <<EOF
+Usage: $PROGNAME [-h] [-n] DIR|FILE.sum...
+
+Rerun unsuccessful tests for testsuites below DIR or for FILE.sum.
+
+ -h display this help and exit
+ -n dry run, only show what would be run
+EOF
+ exit $?
+}
+
+error ()
+{
+ echo "$@" >&2
+ exit 1
+}
+
+dry=
+for arg
+do
+ case $arg in
+ -h | \?) usage ;;
+ -n) dry=:; shift ;;
+ -*) error "unknown argument $arg" ;;
+ *) break ;;
+ esac
+done
+test $# -gt 0 || usage
+
+# Find a good awk.
+if test -z "$AWK" ; then
+ for AWK in gawk nawk awk
+ do
+ if type $AWK 2>&1 | grep 'not found' > /dev/null 2>&1 ; then
+ :
+ else
+ break
+ fi
+ done
+fi
+
+: ${MAKE=make}
+: ${filesuffix=}
+cwd=`pwd`
+files=`find "$@" -name \*.sum$filesuffix -print | grep testsuite | sort`
+st=0
+
+for file in $files; do
+ dir=`echo $file | sed 's,/[^/]*$,,'`
+ base=`echo $file | sed 's,.*/,,; s,\.sum$,,'`
+ flags=`$AWK '
+/^Running .*\.exp \.\.\./ {
+ if (expfile != "" && tests != "")
+ printf (" %s=\"%s\"", expfile, tests)
+ expfile = $2
+ sub (/^[^ ]*\//, "", expfile)
+ sep = ""
+ tests = ""
+}
+/^(FAIL|XPASS|UNRESOLVED|WARNING|ERROR): / {
+ if (test != $2 "" && $2 != "" ) {
+ test = $2
+ tests = tests sep test
+ sep = " "
+ }
+}
+END {
+ if (expfile != "" && tests != "")
+ printf (" %s=\"%s\"", expfile, tests)
+}' $file`
+ if test -n "$flags"; then
+ cd $dir
+ amflags=
+ if grep '^AM_RUNTESTFLAGS =' Makefile >/dev/null 2>&1; then
+ amflags=`echo 'print-runtestflags: ; @echo $(AM_RUNTESTFLAGS)' \
+ | ${MAKE} -s -f Makefile -f - print-runtestflags`
+ fi
+ echo "(cd $dir && runtest $amflags --tool $base $flags)"
+ if test -z "$dry"; then
+ eval runtest --tool $base $flags || st=$?
+ fi
+ cd "$cwd"
+ fi
+done
+exit $st