123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220 |
- #! /bin/sh
- . test-init.sh
- cp "$am_testaux_srcdir"/trivial-test-driver . \
- || fatal_ "failed to fetch auxiliary script trivial-test-driver"
- cat >> configure.ac << 'END'
- AC_OUTPUT
- END
- cat > Makefile.am << 'END'
- TEST_LOG_DRIVER = $(SHELL) $(srcdir)/trivial-test-driver
- TESTS = a.test b.test c.test d.test
- END
- cat > a.test << 'END'
- #! /bin/sh
- echo PASS: aa
- echo PASS: AA
- : > a.run
- END
- cat > b.test << 'END'
- #! /bin/sh
- echo PASS:
- if test -f b.ok; then
- echo PASS:
- else
- echo ERROR:
- fi
- : > b.run
- END
- cat > c.test << 'END'
- #! /bin/sh
- if test -f c.pass; then
- echo PASS: c0
- else
- echo FAIL: c0
- fi
- if test -f c.xfail; then
- echo XFAIL: c1
- else
- echo XPASS: c1
- fi
- echo XFAIL: c2
- : > c.run
- END
- cat > d.test << 'END'
- #! /bin/sh
- echo SKIP: who cares ...
- (. ./d.extra) || echo FAIL: d.extra failed
- : > d.run
- END
- chmod a+x *.test
- $ACLOCAL
- $AUTOCONF
- $AUTOMAKE
- do_recheck ()
- {
- case $* in
- --fail) status=FAIL;;
- --pass) status=0;;
- *) fatal_ "invalid usage of function 'do_recheck'";;
- esac
- rm -f *.run
- run_make -O -e $status recheck || { ls -l; exit 1; }
- ls -l
- }
- for vpath in : false; do
- if $vpath; then
- mkdir build
- cd build
- srcdir=..
- else
- srcdir=.
- fi
- $srcdir/configure
- : A "make recheck" in a clean tree should run no tests.
- using_gmake || $sleep
- do_recheck --pass
- cat test-suite.log
- test ! -e a.run
- test ! -e a.log
- test ! -e b.run
- test ! -e b.log
- test ! -e c.run
- test ! -e c.log
- test ! -e d.run
- test ! -e d.log
- count_test_results total=0 pass=0 fail=0 xpass=0 xfail=0 skip=0 error=0
- : Run the tests for the first time.
- run_make -O -e FAIL check
- ls -l
-
- test -f a.run
- test -f b.run
- test -f c.run
- test -f d.run
- count_test_results total=9 pass=3 fail=2 xpass=1 xfail=1 skip=1 error=1
- : Let us make b.test pass.
- using_gmake || $sleep
- echo OK > b.ok
- do_recheck --fail
-
-
- test ! -e a.run
- test -f b.run
- test -f c.run
- test -f d.run
- count_test_results total=7 pass=2 fail=2 xpass=1 xfail=1 skip=1 error=0
- : Let us make the first part of c.test pass.
- using_gmake || $sleep
- echo OK > c.pass
- do_recheck --fail
- test ! -e a.run
- test ! -e b.run
- test -f c.run
- test -f d.run
- count_test_results total=5 pass=1 fail=1 xpass=1 xfail=1 skip=1 error=0
- : Let us make also the second part of c.test pass.
- using_gmake || $sleep
- echo KO > c.xfail
- do_recheck --fail
- test ! -e a.run
- test ! -e b.run
- test -f c.run
- test -f d.run
- count_test_results total=5 pass=1 fail=1 xpass=0 xfail=2 skip=1 error=0
- : Nothing changed, so only d.test should be run.
- for i in 1 2; do
- using_gmake || $sleep
- do_recheck --fail
- test ! -e a.run
- test ! -e b.run
- test ! -e c.run
- test -f d.run
- count_test_results total=2 pass=0 fail=1 xpass=0 xfail=0 skip=1 error=0
- done
- : Let us make d.test run more testcases, and experience _more_ failures.
- using_gmake || $sleep
- unindent > d.extra <<'END'
- echo SKIP: s
- echo FAIL: f 1
- echo PASS: p 1
- echo FAIL: f 2
- echo XPASS: xp
- echo FAIL: f 3
- echo FAIL: f 4
- echo ERROR: e 1
- echo PASS: p 2
- echo ERROR: e 2
- END
- do_recheck --fail
- test ! -e a.run
- test ! -e b.run
- test ! -e c.run
- test -f d.run
- count_test_results total=11 pass=2 fail=4 xpass=1 xfail=0 skip=2 error=2
- : Let us finally make d.test pass.
- using_gmake || $sleep
- echo : > d.extra
- do_recheck --pass
- test ! -e a.run
- test ! -e b.run
- test ! -e c.run
- test -f d.run
- count_test_results total=1 pass=0 fail=0 xpass=0 xfail=0 skip=1 error=0
- : All tests have been successful or skipped, nothing should be re-run.
- using_gmake || $sleep
- do_recheck --pass
- test ! -e a.run
- test ! -e b.run
- test ! -e c.run
- test ! -e d.run
- count_test_results total=0 pass=0 fail=0 xpass=0 xfail=0 skip=0 error=0
- cd $srcdir
- done
- :
|