diff options
author | Ian Lance Taylor <ian@gcc.gnu.org> | 2011-04-05 21:11:35 +0000 |
---|---|---|
committer | Ian Lance Taylor <ian@gcc.gnu.org> | 2011-04-05 21:11:35 +0000 |
commit | 49fd1b338cb12f6bc6fd90233784fad339d436b6 (patch) | |
tree | 1c2d99e4f774449ca72d334df4a080e48a051b63 /libgo | |
parent | bc8e4748aa3e6c80c608f754b53b958e43088518 (diff) | |
download | gcc-49fd1b338cb12f6bc6fd90233784fad339d436b6.tar.gz |
gotest: Add external timeout if internal timeout fails.
From-SVN: r172003
Diffstat (limited to 'libgo')
-rwxr-xr-x | libgo/testsuite/gotest | 15 |
1 files changed, 14 insertions, 1 deletions
diff --git a/libgo/testsuite/gotest b/libgo/testsuite/gotest index 650e4333c0b..cae420f4f4b 100755 --- a/libgo/testsuite/gotest +++ b/libgo/testsuite/gotest @@ -377,7 +377,20 @@ case "x$dejagnu" in xno) ${GC} -g -c _testmain.go ${GL} *.o ${GOLIBS} - ./a.out -test.short -test.timeout=$timeout "$@" + + ./a.out -test.short -test.timeout=$timeout "$@" & + pid=$! + (sleep `expr $timeout + 10` + echo > gotest-timeout + echo "timed out in gotest" 1>&2 + kill -9 $pid) & + alarmpid=$! + wait $pid + status=$? + if ! test -f gotest-timeout; then + kill $alarmpid + fi + exit $status ;; xyes) rm -rf ../testsuite/*.o |