diff options
author | Mathieu Lirzin <mthl@gnu.org> | 2017-09-20 00:08:59 +0200 |
---|---|---|
committer | Mathieu Lirzin <mthl@gnu.org> | 2017-09-20 00:08:59 +0200 |
commit | 7508174f4a6c19eeda89a7e18b8d1398fe85ccf0 (patch) | |
tree | 2938ba28267cfc6d6cba0b763f80e4b32ce49b03 /t/parallel-tests-empty-testlogs.sh | |
parent | c2757b974cb4c182333859edb45a01194550bc0e (diff) | |
parent | ced195a8556b68eab3dd0887e07a97c6ae4917bf (diff) | |
download | automake-7508174f4a6c19eeda89a7e18b8d1398fe85ccf0.tar.gz |
Merge branch 'minor'
Diffstat (limited to 't/parallel-tests-empty-testlogs.sh')
-rw-r--r-- | t/parallel-tests-empty-testlogs.sh | 94 |
1 files changed, 94 insertions, 0 deletions
diff --git a/t/parallel-tests-empty-testlogs.sh b/t/parallel-tests-empty-testlogs.sh new file mode 100644 index 000000000..55f89e60f --- /dev/null +++ b/t/parallel-tests-empty-testlogs.sh @@ -0,0 +1,94 @@ +#! /bin/sh +# Copyright (C) 2011-2017 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 <https://www.gnu.org/licenses/>. + +# Check parallel-tests features: +# - empty TESTS +# - empty TEST_LOGS + +. test-init.sh + +cat >> configure.ac << 'END' +AC_CONFIG_FILES([sub1/Makefile sub2/Makefile]) +AC_OUTPUT +END + +cat > Makefile.am << 'END' +SUBDIRS = sub1 sub2 +END + +mkdir sub1 sub2 + +cat > sub1/Makefile.am << 'END' +TESTS = +END + +# When $(TESTS) is empty, NetBSD 5.1 make ends up defining $(TESTS_LOGS) +# to ".log" rather than to the empty string (as would be expected). +# But our recipes are smart enough to work around such a botched-up +# substitution, so let's not bother too much about it. +if using_gmake; then + unindent >> sub1/Makefile.am << 'END' + check-local: + echo $(TEST_LOGS) | grep . && exit 1; exit 0 +END +fi + +cat > sub2/Makefile.am << 'END' +TESTS = foo.test +END + +cat > sub2/foo.test <<'END' +#! /bin/sh +exit 0 +END +chmod a+x sub2/foo.test + +$ACLOCAL +$AUTOCONF +$AUTOMAKE -a + +no_test_has_run () +{ + ls -1 *.log | grep -v '^test-suite\.log$' | grep . && exit 1 + grep '^# TOTAL: *0$' test-suite.log + : +} + +for vpath in : false; do + if $vpath; then + mkdir build + cd build + srcdir=.. + else + srcdir=. + fi + $srcdir/configure + cd sub1 + VERBOSE=yes $MAKE check + no_test_has_run + cd ../sub2 + run_make VERBOSE=yes TESTS= check + no_test_has_run + run_make VERBOSE=yes TEST_LOGS= check + no_test_has_run + cd .. + $MAKE check + cat sub2/foo.log + $MAKE distclean + cd $srcdir +done + +: |