diff options
author | Stefano Lattarini <stefano.lattarini@gmail.com> | 2012-10-26 14:50:46 +0200 |
---|---|---|
committer | Stefano Lattarini <stefano.lattarini@gmail.com> | 2012-10-26 15:01:45 +0200 |
commit | 2990f48d423c92f8800f8f50368b6b6d1d1be788 (patch) | |
tree | 95aeb769895495364e089aba937b4631c7369e13 /t/parallel-tests-concurrency.sh | |
parent | 042a2279fe1d030b0deb559c6318213e3cea1f6f (diff) | |
download | automake-2990f48d423c92f8800f8f50368b6b6d1d1be788.tar.gz |
tests: rename some tests to more expressive names, again
* t/parallel-tests.sh: Rename ...
* t/parallel-tests-basics.sh: ... like this.
* t/parallel-tests3.sh: Rename ...
* t/parallel-tests-concurrency.sh: ... like this.
* t/parallel-tests5.sh: Rename ...
* t/parallel-tests-concurrency-2.sh: ... like this.
* t/parallel-tests6.sh: Rename ...
* t/parallel-tests-empty.sh: ... like this. Adjust comments.
* t/parallel-tests8.sh: Rename ...
* t/parallel-tests-generated-and-distributed.sh: ... like this.
* t/parallel-tests9.sh: Rename ...
* t/parallel-tests-recheck.sh: ... like this.
* t/parallel-tests10.sh: Rename ...
* t/parallel-tests-trailing-whitespace.sh: ... like this.
* t/remake3a.sh: Rename ...
* t/remake-subdir-no-makefile.sh: ... like this.
* t/remake4.sh: Rename ...
* t/remake-not-after-make-dist.sh: ... like this.
* t/remake5.sh: Rename ...
* t/remake-maintainer-mode.sh: ... like this.
* t/remake6.sh: Rename ...
* t/remake-subdir3.sh: ... like this.
* t/remake7.sh: Rename ...
* t/remake-fail.sh: ... like this.
* t/remake11.sh: Rename ...
* t/remake-deeply-nested.sh: ... like this
* t/remake12.sh: Rename ...
* t/remake-mild-stress.sh: ... like this
* t/pr8365-remake-timing.sh: Rename ...
* t/remake-timing-bug-pr8365.sh: ... like this.
* t/list-of-tests.mk: Adjust.
Signed-off-by: Stefano Lattarini <stefano.lattarini@gmail.com>
Diffstat (limited to 't/parallel-tests-concurrency.sh')
-rwxr-xr-x | t/parallel-tests-concurrency.sh | 114 |
1 files changed, 114 insertions, 0 deletions
diff --git a/t/parallel-tests-concurrency.sh b/t/parallel-tests-concurrency.sh new file mode 100755 index 000000000..b606276fa --- /dev/null +++ b/t/parallel-tests-concurrency.sh @@ -0,0 +1,114 @@ +#! /bin/sh +# Copyright (C) 2009-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: +# - concurrent parallel execution + +. ./defs || exit 1 + +case $MAKE in + *\ -j*) skip_ "\$MAKE contains '-j'";; +esac + +if using_gmake; then + j=-j +else + unindent > Makefile <<END + all: one two + one: + $sleep && test -f two + two: + echo ok > \$@ +END + for j in "-j" "-j " NONE; do + if test x"$j" = xNONE; then + skip_ "can't run make in parallel mode" + fi + $MAKE ${j}2 all >output 2>&1 || continue + $EGREP -i "(warning|error):|-j[\"\'\` ]" output && continue + break + done + rm -f one output Makefile +fi + +cat >> configure.ac << 'END' +AC_OUTPUT +END + +cat > Makefile.am << 'END' +TESTS = +END + +cat > x <<'END' +#! /bin/sh +echo "this is $0" +# Creative quoting below to please maintainer-check. +sleep '1' +exit 0 +END +chmod a+x ./x + +mkdir sub +for i in 1 2 3; do + echo "TESTS += foo$i.test" >> Makefile.am + cp x foo$i.test + echo "TESTS += zap$i" >> Makefile.am + cp x zap$i + echo "TESTS += sub/bar$i.test" >> Makefile.am + cp x sub/bar$i.test + echo "TESTS += sub/mu$i" >> Makefile.am + cp x sub/mu$i +done + +$ACLOCAL +$AUTOCONF +$AUTOMAKE -a + +for build in serial parallel; do + mkdir $build + cd $build + ../configure + $MAKE + cd .. +done + +cd serial +$MAKE ${j}1 check & +cd ../parallel +$sleep +# Use append mode here to avoid dropping output. See automake bug#11413. +: > stdout +$MAKE ${j}4 check >> stdout +cd .. +# Ensure the tests are really being run in parallel mode: if this is +# the case, the serial run of the dummy testsuite started above should +# still be ongoing when the parallel one has terminated. +kill -0 $! +cat parallel/stdout +test $(grep -c '^PASS:' parallel/stdout) -eq 12 + +# Wait long enough so that there are no open files any more when the +# post-test cleanup runs. But exit after we've waited for two minutes +# or more, to avoid testsuite hangs in unusual situations (this has +# already happened). +i=1 +while test ! -f serial/test-suite.log && test $i -le 120; do + i=$(($i + 1)) + sleep '1' # Extra quoting to please maintainer-check. +done +$sleep + +: |