X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=tests%2Frun-all;h=736e0fe0a9189a42ef7295648a3630305085b10b;hb=b093090b8d5a24cbc40a9e9b517f3f55a2144d47;hp=551e51ffb8ea298e522c16b08ea92a9e0c83a3c2;hpb=a110a1029e0eefe70bb1c057620c4102c6a52165;p=dgit.git diff --git a/tests/run-all b/tests/run-all index 551e51ff..736e0fe0 100755 --- a/tests/run-all +++ b/tests/run-all @@ -1,10 +1,59 @@ -#!/bin/sh +#!/bin/bash set -e # convenience script for running the tests outside adt-run -for f in `run-parts --list tests/tests`; do - echo ================================================== - echo $f - $f - echo ================================================== +# usage: tests/using-intree tests/run-all [-p|--progressive] [tests/tests/*] +# +# passing `:' as if it were tests/tests/something is +# a no-op and therefore just means to (delete and) set up the tmpdir + +set -o pipefail + +while [ $# != 0 ]; do + case "$1" in + --progressive|-p) shift; export DGIT_TESTS_PROGRESSIVE=y;; + --) shift; break ;; + -*) echo >&2 "run-all: unknown option $1"; exit 20 ;; + *) break ;; + esac done -echo "ALL PASSED" + +ncpus=$(nproc || echo 1) +jcpus=-j$(( ncpus * 134 / 100 )) + +if [ "x$DGIT_TESTS_TMPDIR" != x ]; then + tmpdir="$PWD" + tmpdir="${tmpdir#/}" + tmpdir="${tmpdir//!/!#!}" + tmpdir="${tmpdir//\//!}" + tmpdir="$DGIT_TESTS_TMPDIR/$tmpdir" + rm -f tests/tmp + ln -ns -- "$tmpdir" tests/tmp +else + tmpdir=tests/tmp +fi + +case "$DGIT_TESTS_PROGRESSIVE" in +''|n) + rm -rf -- "$tmpdir" + ;; +esac + +mkdir -p -- "$tmpdir" + +case "$1" in +:) + shift + if [ $# = 0 ]; then exit 0; fi + ;; +esac + +if [ $# != 0 ]; then + set TESTSCRIPTS="$*" +fi + +export DGIT_GNUPG_STUNT_ERRLOG=$( tty -s ||: ) + +( + set -x + exec make $jcpus -k -f tests/Makefile "$@" +) 2>&1 |tee tests/tmp/run-all.log