X-Git-Url: https://git.notmuchmail.org/git?p=notmuch;a=blobdiff_plain;f=test%2Fnotmuch-test;h=ba28ff3908e4d415f0bbbdf4ea11f6b5d99f6570;hp=43565e87f55d76ada462b07f6b861518fc105a36;hb=ac8576de63b4383aef597e1db5af939e3b46594c;hpb=e2a550b968010e0bb7b5d519ef33409f0cf2f28d diff --git a/test/notmuch-test b/test/notmuch-test index 43565e87..ba28ff39 100755 --- a/test/notmuch-test +++ b/test/notmuch-test @@ -1,4 +1,4 @@ -#!/bin/bash +#!/usr/bin/env bash # Run tests # @@ -14,30 +14,63 @@ if [ ${BASH_VERSINFO[0]} -lt 4 ]; then exit 1 fi -set -e - -die () { - echo >&2 "Unexpected failure" -} - -trap 'die' 0 - cd $(dirname "$0") -TESTS="basic new search search-output json thread-naming raw reply dump-restore uuencode thread-order author-order from-guessing long-id encoding emacs maildir-sync" +TESTS=" + basic + help-test + 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} # Clean up any results from a previous run -rm -rf test-results >/dev/null 2>/dev/null +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 $! done +trap - HUP INT TERM # Report results ./aggregate-results.sh test-results/* # Clean up -rm -r test-results corpus.mail - -trap '' 0 +rm -rf test-results corpus.mail