-#!/bin/bash
+#!/usr/bin/env bash
# Run tests
#
cd $(dirname "$0")
-TESTS="basic new search search-output search-by-folder search-position-overlap-bug json thread-naming raw reply dump-restore uuencode thread-order author-order from-guessing long-id encoding emacs maildir-sync"
+TESTS="
+ basic
+ help-test
+ config
+ new
+ count
+ search
+ search-output
+ search-by-folder
+ search-position-overlap-bug
+ search-insufficient-from-quoting
+ search-limiting
+ excludes
+ tagging
+ json
+ text
+ multipart
+ thread-naming
+ raw
+ reply
+ reply-to-sender
+ dump-restore
+ uuencode
+ thread-order
+ author-order
+ from-guessing
+ long-id
+ 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
+ missing-headers
+ parse-time-string
+ search-date
+"
+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 $!
done
+trap - HUP INT TERM
# Report results
./aggregate-results.sh test-results/*
# Clean up
-rm -r test-results corpus.mail
+rm -rf test-results corpus.mail