X-Git-Url: https://git.cworth.org/git?p=notmuch;a=blobdiff_plain;f=test%2Fnotmuch-test;h=14747bdbfc44d040cc0118d3d84328a7c69e6e06;hp=b8437127c01fccc98c6f9be595f6cd1b8b0ebb5c;hb=fb4a0967cab7df737d5d53199a48a0e79c429b61;hpb=28d7544ae2adfe6467c6b64a3284f5ed13f81e1a diff --git a/test/notmuch-test b/test/notmuch-test index b8437127..14747bdb 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,41 +15,85 @@ if [ ${BASH_VERSINFO[0]} -lt 4 ]; then exit 1 fi -cd $(dirname "$0") +# Ensure NOTMUCH_SRCDIR and NOTMUCH_BUILDDIR are set. +. $(dirname "$0")/export-dirs.sh || exit 1 -TESTS=${NOTMUCH_TESTS:-`echo T[0-9][0-9][0-9]-*.sh`} +set -eu + +TESTS= +for test in ${NOTMUCH_TESTS-}; do + TESTS="$TESTS $NOTMUCH_SRCDIR/test/$test" +done + +if [ -z "$TESTS" ]; then + TESTS="$NOTMUCH_SRCDIR/test/T[0-9][0-9][0-9]-*.sh" +fi # Clean up any results from a previous run -rm -r test-results >/dev/null 2>/dev/null +rm -rf $NOTMUCH_BUILDDIR/test/test-results -# test for timeout utility +# Test for timeout utility if command -v timeout >/dev/null; then - TEST_TIMEOUT_CMD="timeout 2m " - echo "INFO: using 2 minute timeout for tests" + TEST_TIMEOUT=${NOTMUCH_TEST_TIMEOUT:-2m} + if [ "$TEST_TIMEOUT" = 0 ]; then + TEST_TIMEOUT_CMD="" + echo "INFO: timeout disabled" + else + TEST_TIMEOUT_CMD="timeout $TEST_TIMEOUT" + echo "INFO: using $TEST_TIMEOUT timeout for tests" + fi else TEST_TIMEOUT_CMD="" fi -trap 'e=$?; kill $!; exit $e' HUP INT TERM +META_FAILURE= +RES=0 # Run the tests -for test in $TESTS; do - $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 +if test -z "${NOTMUCH_TEST_SERIALIZE-}" && command -v parallel >/dev/null ; then + test -t 1 && export COLORS_WITHOUT_TTY=t || : + if parallel --minversion 0 >/dev/null 2>&1 ; then + echo "INFO: running tests with GNU parallel" + printf '%s\n' $TESTS | $TEST_TIMEOUT_CMD parallel || RES=$? + else + echo "INFO: running tests with moreutils parallel" + $TEST_TIMEOUT_CMD parallel -- $TESTS || RES=$? fi -done -trap - HUP INT TERM + if [ $RES != 0 ]; then + META_FAILURE="parallel test suite returned error code $RES" + fi +else + trap 'e=$?; trap - 0; kill ${!-}; exit $e' 0 HUP INT TERM + for test in $TESTS; do + $TEST_TIMEOUT_CMD $test "$@" & + wait $! && ev=0 || ev=$? + test $ev = 0 || RES=$ev + done + trap - 0 HUP INT TERM + if [ $RES != 0 ]; then + META_FAILURE="some tests failed; first failed returned error code $RES" + fi +fi # Report results +RESULT_FILES= +for file in $TESTS +do + file=${file##*/} # drop leading path components + file=${file%.sh} # drop trailing '.sh' + RESULT_FILES="$RESULT_FILES $NOTMUCH_BUILDDIR/test/test-results/$file" +done + echo -./aggregate-results.sh test-results/* -ev=$? +$NOTMUCH_SRCDIR/test/aggregate-results.sh $RESULT_FILES && ev=0 || ev=$? + +if [ -n "$META_FAILURE" ]; then + printf 'ERROR: %s\n' "$META_FAILURE" + if [ $ev = 0 ]; then + ev=$RES + fi +fi # Clean up -rm -rf test-results corpus.mail +rm -rf $NOTMUCH_BUILDDIR/test/test-results exit $ev