Hash :
5ddf1007
Author :
Date :
2012-10-27T16:41:39
tests: prefer including 'test-init.sh' rather than './defs'
This is a follow-up to today's commit v1.12.4-22-g0610fc8,
"tests: prepare to move ./defs to t/ax/test-init.sh"
* All tests: To run the common setup, use the command:
. test-init.sh
instead of the older, "historical" one:
. ./defs || exit 1
Note that the "|| exit 1" wasn't really useful, since the 'errexit'
shell flag is in effect in both './defs' and 'test-init.sh', and all
the known shells that are good enough to run the automake testsuite
do automatically exit with error when a sourced file cannot be found
(at least, they do so in non-interactive mode, which is the only
mode that concerns us in the testsuite).
* t/ax/tap-summary-aux.sh, t/ax/testsuite-summary-checks.sh: Likewise.
* gen-testsuite-part: Do the same in the generated tests.
Signed-off-by: Stefano Lattarini <stefano.lattarini@gmail.com>
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102
#! /bin/sh
# Copyright (C) 2011-2012 Free Software Foundation, Inc.
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2, or (at your option)
# any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
# Check parallel-tests features: runtime redefinition of $(TEST_SUITE_LOG)
# for the recheck target.
. test-init.sh
cat >> configure.ac <<'END'
AC_OUTPUT
END
cat > Makefile.am <<'END'
TESTS = foofoo.test barbar.test bazbaz.test
END
cat > foofoo.test <<'END'
#! /bin/sh
echo "this is $0"
exit 0
END
cat > barbar.test <<'END'
#! /bin/sh
echo "this is $0"
exit 99
END
cat > bazbaz.test <<'END'
#! /bin/sh
echo "this is $0"
exit ${BAZ_EXIT_STATUS-1}
END
chmod a+x *.test
unset BAZ_EXIT_STATUS || :
$ACLOCAL
$AUTOCONF
$AUTOMAKE -a
# Filter make output before grepping it, for make implementations that,
# like Solaris' one, print the whole of the failed recipe on failure.
filter_stdout ()
{
grep -v 'bases=.*;' stdout > t && mv -f t stdout
}
./configure
$MAKE check >stdout && { cat stdout; exit 1; }
cat stdout
using_gmake || $sleep # Required by BSD make.
chmod a-rw test-suite.log
TEST_SUITE_LOG=my.log $MAKE -e recheck >stdout \
&& { cat stdout; exit 1; }
cat stdout
ls -l
filter_stdout
count_test_results total=2 pass=0 fail=1 skip=0 xfail=0 xpass=0 error=1
for x in stdout my.log; do
$FGREP foofoo $x && exit 1
$FGREP barbar $x
$FGREP bazbaz $x
done
using_gmake || $sleep # Required by BSD make.
chmod a-rw my.log
BAZ_EXIT_STATUS=0 TEST_SUITE_LOG=my2.log $MAKE -e recheck >stdout \
&& { cat stdout; exit 1; }
cat stdout
ls -l
count_test_results total=2 pass=1 fail=0 skip=0 xfail=0 xpass=0 error=1
filter_stdout
$FGREP foofoo stdout && exit 1
$FGREP barbar stdout
$FGREP bazbaz stdout
$FGREP foofoo my2.log && exit 1
$FGREP barbar my2.log
$FGREP bazbaz my2.log && exit 1
chmod u+r test-suite.log my.log
$FGREP bazbaz test-suite.log
$FGREP bazbaz my.log
: