X-Git-Url: https://git.notmuchmail.org/git?p=notmuch;a=blobdiff_plain;f=test%2Fnotmuch-test;h=8e483383f79d67aa7d87c04949e51407ddb7542d;hp=e7d3151ce8cbb528c68d6526ba4c39a035d5a1eb;hb=3563079be37737aab084e957b494070eaea9c2f6;hpb=07dff496304d6dc2e8033a18691b095ed9cd212f diff --git a/test/notmuch-test b/test/notmuch-test index e7d3151c..8e483383 100755 --- a/test/notmuch-test +++ b/test/notmuch-test @@ -15,41 +15,67 @@ 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:-T[0-9][0-9][0-9]-*.sh} +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 -rf test-results +rm -rf $NOTMUCH_BUILDDIR/test/test-results # 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} + TEST_TIMEOUT_CMD="timeout $TEST_TIMEOUT" + echo "INFO: using $TEST_TIMEOUT timeout for tests" 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 "$@" & - wait $! - # If the test failed without producing results, then it aborted, - # so we should abort, too. +if test -z "$NOTMUCH_TEST_SERIALIZE" && command -v parallel >/dev/null ; then + test -t 1 && export COLORS_WITHOUT_TTY=t || : + if parallel -h | grep -q GNU ; then + echo "INFO: running tests with GNU parallel" + printf '%s\n' $TESTS | $TEST_TIMEOUT_CMD parallel + else + echo "INFO: running tests with moreutils parallel" + $TEST_TIMEOUT_CMD parallel -- $TESTS + fi RES=$? - if [[ $RES != 0 && ! -e "test-results/${test%.sh}" ]]; then + if [[ $RES != 0 ]]; then + echo "parallel test suite returned error code $RES" exit $RES fi -done +else + 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=$? + testname=$(basename $test .sh) + if [[ $RES != 0 && ! -e "$NOTMUCH_BUILDDIR/test/test-results/$testname" ]]; then + exit $RES + fi + done +fi trap - HUP INT TERM # Report results echo -./aggregate-results.sh test-results/* +$NOTMUCH_SRCDIR/test/aggregate-results.sh $NOTMUCH_BUILDDIR/test/test-results/* ev=$? # Clean up -rm -rf test-results corpus.mail +rm -rf $NOTMUCH_BUILDDIR/test/test-results exit $ev