| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212 | #! /bin/sh# Copyright (C) 2010-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/>.# Test to make sure dejagnu tests, automake-style tests, and check-local# target can coexist.# For gen-testsuite-part: ==> try-with-serial-tests <==required=runtest. test-init.shcat >> configure.ac << 'END'AC_OUTPUTENDcat > Makefile.am << 'END'AUTOMAKE_OPTIONS =EXTRA_DIST =CLEANFILES =END## Simple tests.cat > a.test << 'END'#!/bin/shecho a.test: exit status: ${A_EXIT_STATUS-0}exit ${A_EXIT_STATUS-0}ENDcat > b.test << 'END'#!/bin/shecho b.test: exit status: ${B_EXIT_STATUS-0}exit ${B_EXIT_STATUS-0}ENDchmod +x a.test b.testcat >> Makefile.am << 'END'TESTS = a.test b.testEXTRA_DIST += $(TESTS)ENDA_EXIT_STATUS=0; export A_EXIT_STATUSB_EXIT_STATUS=0; export B_EXIT_STATUS## DejaGnu tests.cat >> Makefile.am << 'END'AUTOMAKE_OPTIONS += dejagnuDEJATOOL = hammer spannerAM_RUNTESTFLAGS = HAMMER=$(srcdir)/hammer SPANNER=$(srcdir)/spannerEXTRA_DIST += hammer.test/hammer.expEXTRA_DIST += spanner.test/spanner.expENDcat > hammer << 'END'#! /bin/shecho "Everything looks like a ${NAIL-nail} to me!"ENDNAIL=nail; export NAILcat > spanner << 'END'#! /bin/shecho "I'm a right spanner!"ENDchmod +x hammer spannermkdir hammer.test spanner.testcat > hammer.test/hammer.exp << 'END'set test test_hammerspawn $HAMMERexpect {    "Everything looks like a nail to me!" { pass "$test" }    default { fail "$test" }}ENDcat > spanner.test/spanner.exp << 'END'set test test_spannerspawn $SPANNERexpect {    "I'm a right spanner!" { pass "$test" }    default { fail "$test" }}END## User-defined extra tests.cat >> Makefile.am <<'END'check-local:	case $$CHECKLOCAL_EXIT_STATUS in \	  0) echo 'check-local succeeded :-)';; \	  *) echo 'check-local failed :-(';; \	esac >local.log	exit $$CHECKLOCAL_EXIT_STATUSCLEANFILES += local.logENDCHECKLOCAL_EXIT_STATUS=0; export CHECKLOCAL_EXIT_STATUS## Go with the testcase execution.$ACLOCAL$AUTOCONF$AUTOMAKE --add-missingfor vpath in : false; do  if $vpath; then    srcdir=..    mkdir build    cd build  else    srcdir=.  fi  if test -f config.status; then    $MAKE distclean  fi  $srcdir/configure  $MAKE check  test -f hammer.log  test -f hammer.sum  test -f spanner.log  test -f spanner.sum  if test x"$am_serial_tests" != x"yes"; then    test -f test-suite.log    test -f a.log    test -f b.log  fi  grep 'check-local succeeded :-)' local.log  cp -f config.status config-status.sav  $MAKE distclean  test ! -e hammer.log  test ! -e hammer.sum  test ! -e spanner.log  test ! -e spanner.sum  test ! -e test-suite.log  test ! -e a.log  test ! -e b.log  test ! -e local.log  mv -f config-status.sav config.status  ./config.status  NAIL=screw $MAKE check && exit 1  test -f hammer.log  test -f hammer.sum  test -f spanner.log  test -f spanner.sum  grep 'FAIL: test_hammer' hammer.sum  grep 'FAIL:' spanner.sum && exit 1  B_EXIT_STATUS=1 $MAKE check && exit 1  if test x"$am_serial_tests" != x"yes"; then    cat test-suite.log    cat a.log    cat b.log    grep '^a\.test: exit status: 0$' a.log    grep '^b\.test: exit status: 1$' b.log    grep '^FAIL: b$' test-suite.log    grep '^b\.test: exit status: 1$' test-suite.log    grep '^a\.test' test-suite.log && exit 1    : For shells with busted 'set -e'.  fi  CHECKLOCAL_EXIT_STATUS=1 $MAKE check && exit 1  grep 'check-local failed :-(' local.log  # Do not trust the exit status of 'make -k'.  NAIL=screw B_EXIT_STATUS=23 CHECKLOCAL_EXIT_STATUS=1 $MAKE -k check || :  test -f hammer.log  test -f hammer.sum  test -f spanner.log  test -f spanner.sum  grep 'FAIL: test_hammer' hammer.sum  grep 'FAIL:' spanner.sum && exit 1  if test x"$am_serial_tests" != x"yes"; then    cat test-suite.log    cat a.log    cat b.log    grep '^a\.test: exit status: 0$' a.log    grep '^b\.test: exit status: 23$' b.log    grep '^FAIL: b$' test-suite.log    grep '^b\.test: exit status: 23$' test-suite.log    grep '^a\.test' test-suite.log && exit 1    : For shells with busted 'set -e'.  fi  grep 'check-local failed :-(' local.log  cd $srcdirdone$MAKE distcheck:
 |