| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144 | #! /bin/sh# Copyright (C) 2009-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 <http://www.gnu.org/licenses/>.# Check parallel-tests features:#  - check-html#  - recheck-html. test-init.sh# Try the variants that are tried in check-html.am.while :; do  for r2h in $RST2HTML rst2html rst2html.py; do    echo "$me: running $r2h --version"    $r2h --version && break 2    : For shells with busted 'set -e'.  done  skip_all_ "no proper rst2html program found"doneunset r2hcp "$am_top_srcdir"/contrib/check-html.am . \  || fatal_ "cannot fetch 'check-html.am' from contrib"cat >> configure.ac << 'END'AC_OUTPUTENDcat > Makefile.am << 'END'TEST_SUITE_LOG = mylog.logTESTS = foo.test bar.test baz.testcheck_SCRIPTS = blabla:	echo bla > $@CLEANFILES = blainclude $(srcdir)/check-html.amENDcat > foo.test <<'END'#! /bin/shecho "this is $0"test -f bla || exit 1exit 0ENDcat > bar.test <<'END'#! /bin/shecho "this is $0"exit 99ENDcat > baz.test <<'END'#! /bin/shecho "this is $0"exit 1ENDchmod a+x foo.test bar.test baz.test$ACLOCAL$AUTOCONF$AUTOMAKE -a./configure$MAKE check-html && exit 1test -f mylog.html# check-html should cause check_SCRIPTS to be created.test -f bla# "make clean" should remove HTML files.$MAKE cleantest ! -e mylog.htmltest ! -e bla# Always create the HTML output, even if there were no failures.rm -f mylog.htmlrun_make TESTS=foo.test check-htmltest -f mylog.html# Create summarizing HTML output also with recheck-html.rm -f mylog.htmlrun_make TESTS=foo.test recheck-htmltest -f mylog.html# Create HTML output for an individual test.$MAKE foo.htmlgrep 'this is .*foo\.test' foo.htmltest ! -e bar.htmltest ! -e baz.html# Create HTML output for individual tests.  Since the pre-existing log# files are expected to be used for the HTML conversion, this should# go smoothly even for failed tests.$MAKE bar.html baz.htmlgrep 'this is .*bar\.test' bar.htmlgrep 'this is .*baz\.test' baz.html# HTML output removed by mostlyclean.$MAKE mostlycleantest ! -e foo.htmltest ! -e bar.htmltest ! -e baz.htmltest ! -e mylog.html# check-html and recheck-html should cause check_SCRIPTS to be created,# and recheck-html should rerun no tests if check has not been run.$MAKE cleantest ! -e mylog.htmlrun_make TEST_LOGS=foo.log check-htmltest -f blatest -f foo.logtest ! -e bar.logtest ! -e baz.logtest -f mylog.html$MAKE cleanrun_make TESTS=foo.test recheck-htmltest -f blatest ! -e foo.logtest -f mylog.html$MAKE clean$MAKE recheck-htmltest -f blatest ! -e foo.logtest ! -e bar.logtest ! -e baz.logtest -f mylog.html:
 |