X-Git-Url: https://git.notmuchmail.org/git?p=notmuch;a=blobdiff_plain;f=test%2Fnotmuch-test;h=988dce6c59cb5533d4a703fd52748f030c6b0d41;hp=adfd589fe0765d19d575d4714f59ef4f352b6022;hb=b183f2635eaf323066f26c7ca22d931d4f4ccd3a;hpb=8a4d631d7c9bd3775ae91fe577498d580c918c0a diff --git a/test/notmuch-test b/test/notmuch-test index adfd589f..988dce6c 100755 --- a/test/notmuch-test +++ b/test/notmuch-test @@ -3,6 +3,7 @@ # Run tests # # Copyright (c) 2005 Junio C Hamano +# Copyright (c) 2010 Notmuch Developers # # Adapted from a Makefile to a shell script by Carl Worth (2010) @@ -14,40 +15,9 @@ if [ ${BASH_VERSINFO[0]} -lt 4 ]; then exit 1 fi -cd $(dirname "$0") +cd "$(dirname "$0")" -TESTS=" - basic - new - count - search - search-output - search-by-folder - search-position-overlap-bug - search-insufficient-from-quoting - search-limiting - tagging - json - multipart - thread-naming - raw - reply - dump-restore - uuencode - thread-order - author-order - from-guessing - long-id - encoding - emacs - emacs-large-search-buffer - maildir-sync - crypto - symbol-hiding - search-folder-coherence - atomicity -" -TESTS=${NOTMUCH_TESTS:=$TESTS} +TESTS=${NOTMUCH_TESTS:-`echo T[0-9][0-9][0-9]-*.sh`} # Clean up any results from a previous run rm -r test-results >/dev/null 2>/dev/null @@ -60,13 +30,26 @@ else TEST_TIMEOUT_CMD="" fi +trap 'e=$?; kill $!; exit $e' HUP INT TERM # Run the tests for test in $TESTS; do - $TEST_TIMEOUT_CMD ./$test "$@" + $TEST_TIMEOUT_CMD ./$test "$@" & + wait $! + # If the test failed without producing results, then it aborted, + # so we should abort, too. + RES=$? + if [[ $RES != 0 && ! -e "test-results/${test%.sh}" ]]; then + exit $RES + fi done +trap - HUP INT TERM # Report results +echo ./aggregate-results.sh test-results/* +ev=$? # Clean up rm -rf test-results corpus.mail + +exit $ev