Merge branch master into maint after 1.12 release
[platform/upstream/automake.git] / t / tap-merge-stdout-stderr.sh
1 #! /bin/sh
2 # Copyright (C) 2011-2012 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 #  - The Automake TAP driver has an option that instruct it to read TAP
19 #    input also from the stderr of the test command, not only its stdout.
20
21 am_parallel_tests=yes
22 . ./defs || Exit 1
23
24 fetch_tap_driver
25
26 cat > Makefile.am << 'END'
27 AM_TEST_LOG_DRIVER_FLAGS = --comments --merge
28 TESTS = all.test
29 END
30
31 . "$am_testauxdir"/tap-setup.sh || fatal_ "sourcing tap-setup.sh"
32
33 cat > all.test <<END
34 #!/bin/sh
35 echo 1..4
36 echo ok 1 >&2
37 echo ok 2
38 echo "not ok 3 # TODO" >&2
39 echo "ok 4 # SKIP"
40 echo "# foo foo foo" >&2
41 END
42 chmod a+x all.test
43
44 $MAKE check >stdout || { cat stdout; Exit 1; }
45 cat stdout
46
47 count_test_results total=4 pass=2 fail=0 xpass=0 xfail=1 skip=1 error=0
48 grep '^# all\.test: foo foo foo' stdout
49
50 cat > all.test <<END
51 #!/bin/sh
52 echo 1..1
53 echo ok 1
54 echo 'Bail out!' >&2
55 END
56
57 $MAKE check >stdout && { cat stdout; Exit 1; }
58 cat stdout
59
60 count_test_results total=2 pass=1 fail=0 xpass=0 xfail=0 skip=0 error=1
61
62 # See that the option '--no-merge' can override the effect of '--merge'.
63
64 TEST_LOG_DRIVER_FLAGS=--no-merge $MAKE -e check >stdout \
65   || { cat stdout; Exit 1; }
66 cat stdout
67
68 count_test_results total=1 pass=1 fail=0 xpass=0 xfail=0 skip=0 error=0
69
70
71
72 :