Hash :
42a46524
Author :
Date :
2011-04-21T10:25:01
check: document and test $(TEST_SUITE_LOG) overriding * doc/automake.texi (Simple Tests using parallel-tests): Explain how and why TEST_SUITE_LOG can be overridden at runtime. * tests/parallel-tests-log-override-1.test: New test, check that the newly documented idiom and similar usages are truly supported. * tests/parallel-tests-log-override-2.test: Likewise. * tests/parallel-tests-log-override-recheck.test: Likewise. * tests/Makefile.am (TESTS): Update.
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
#! /bin/sh
# Copyright (C) 2011 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) and $(TESTS)
# - $(TEST_SUITE_LOG) and $(TEST_LOGS)
parallel_tests=yes
. ./defs || Exit 1
set -e
cat >> configure.in <<'END'
AC_OUTPUT
END
cat > Makefile.am <<'END'
TESTS = pass.test pass2.test skip.test skip2.test fail.test
END
cat > pass.test <<'END'
#! /bin/sh
exit 0
END
cp pass.test pass2.test
cat > skip.test <<'END'
#! /bin/sh
echo "% skipped test %"
exit 77
END
cp skip.test skip2.test
cat > fail.test <<'END'
#! /bin/sh
exit 1
END
chmod a+x *.test
$ACLOCAL
$AUTOCONF
$AUTOMAKE -a
./configure
for test_list_override in \
'TESTS=pass.test skip.test' \
'TEST_LOGS=pass.log skip.log'
do
env TEST_SUITE_LOG=partial.log "$test_list_override" \
$MAKE -e check >stdout || { cat stdout; Exit 1; }
cat stdout
ls -l
cat pass.log
cat skip.log
cat partial.log
test ! -f test-suite.log
test ! -f pass2.log
test ! -f skip2.log
test ! -f fail.log
grep '^PASS: .*pass\.test' stdout
grep '^SKIP: .*skip\.test' stdout
$FGREP 'skip.test' partial.log
$FGREP '% skipped test %' partial.log
for t in pass2 skip2 fail; do
$FGREP "$t.test" stdout && Exit 1
$FGREP "$t.test" partial.log && Exit 1
done
rm -f *.log
done
: