test harness: improve catching of usage errors in script 'test-driver'
[platform/upstream/automake.git] / t / tap-passthrough-exit.sh
1 #! /bin/sh
2 # Copyright (C) 2011-2013 Free Software Foundation, Inc.
3 #
4 # This program is free software; you can redistribute it and/or modify
5 # it under the terms of the GNU General Public License as published by
6 # the Free Software Foundation; either version 2, or (at your option)
7 # any later version.
8 #
9 # This program is distributed in the hope that it will be useful,
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12 # GNU General Public License for more details.
13 #
14 # You should have received a copy of the GNU General Public License
15 # along with this program.  If not, see <http://www.gnu.org/licenses/>.
16
17 # TAP support:
18 #  - non-success exit status of a test script is reported in the
19 #    log file
20 # See also related test 'tap-passthrough.sh'.
21
22 . test-init.sh
23
24 cat > Makefile.am << 'END'
25 TEST_LOG_COMPILER = $(SHELL)
26 TESTS =
27 END
28
29 exit_statuses='1 2 77 99'
30
31 for e in $exit_statuses; do
32   unindent > exit-$e.test <<END
33     #!/bin/sh
34     echo 1..1
35     echo ok 1
36     exit $e
37 END
38   echo TESTS += exit-$e.test >> Makefile.am
39 done
40
41 . tap-setup.sh
42
43 st=0
44 $MAKE check || st=$?
45 for e in $exit_statuses; do cat exit-$e.log; done
46 cat test-suite.log
47 test $st -gt 0 || exit 1
48
49 for e in $exit_statuses; do
50   for log in exit-$e.log test-suite.log; do
51     grep "^ERROR: exit-$e\\.test - exited with status $e$" $log
52   done
53 done
54
55 run_make check TEST_LOG_DRIVER_FLAGS='--ignore-exit'
56 $FGREP ".test - exited with status" *.log && exit 1
57
58 :