X-Git-Url: https://git.notmuchmail.org/git?p=notmuch;a=blobdiff_plain;f=test%2Fnotmuch-test;h=d6fdd3a5d7f3a07d2db111643c80e40fb29a5698;hp=8dd9c1ecf097d69e6084e25ada74bcc8af3102a8;hb=79b6b0190b36f5c9f14af48a3af675d2a16a46f3;hpb=4e414e2a5a72e8345df6371b3524030d07c2ce96 diff --git a/test/notmuch-test b/test/notmuch-test index 8dd9c1ec..d6fdd3a5 100755 --- a/test/notmuch-test +++ b/test/notmuch-test @@ -1,4 +1,4 @@ -#!/bin/bash +#!/usr/bin/env bash # Run tests # @@ -18,16 +18,29 @@ cd $(dirname "$0") TESTS=" basic + help-test + compact + config + setup new + count + insert search search-output search-by-folder search-position-overlap-bug search-insufficient-from-quoting + search-limiting + excludes + tagging json + sexp + text + multipart thread-naming raw reply + reply-to-sender dump-restore uuencode thread-order @@ -37,19 +50,59 @@ TESTS=" encoding emacs emacs-large-search-buffer + emacs-subject-to-filename maildir-sync + crypto + symbol-hiding + search-folder-coherence + atomicity + python + hooks + argument-parsing + emacs-test-functions + emacs-address-cleaning + emacs-hello + emacs-show + emacs-tree + missing-headers + hex-escaping + parse-time-string + search-date + thread-replies " +TESTS=${NOTMUCH_TESTS:=$TESTS} # Clean up any results from a previous run rm -r test-results >/dev/null 2>/dev/null +# test for timeout utility +if command -v timeout >/dev/null; then + TEST_TIMEOUT_CMD="timeout 2m " + echo "INFO: using 2 minute 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 "$@" + $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 -r test-results corpus.mail +rm -rf test-results corpus.mail + +exit $ev