tests: avoid use of redirected 'run_make' invocations
[platform/upstream/automake.git] / t / parallel-tests-basics.sh
1 #! /bin/sh
2 # Copyright (C) 2009-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 # Basic checks on parallel-tests support:
18 #  - console output
19 #  - log files, and what goes in 'test-suite.log'
20 #  - make clean
21 #  - dependencies between tests
22 #  - TESTS redefinition at runtime
23 #  - TEST_LOGS redefinition at runtime
24 #  - RECHECK_LOGS redefinition at runtime
25
26 . test-init.sh
27
28 cat >> configure.ac << 'END'
29 AC_OUTPUT
30 END
31
32 cat > Makefile.am << 'END'
33 TESTS = foo.test bar.test baz.test
34 XFAIL_TESTS = bar.test
35 foo.log: bar.log
36 bar.log: baz.log
37 END
38
39 # foo.test and bar.test sleep to ensure their logs are always strictly newer
40 # than the logs of their prerequisites, for HP-UX make.  The quoting pleases
41 # maintainer-check.
42 cat > foo.test <<'END'
43 #! /bin/sh
44 echo "this is $0"
45 sleep '1'
46 exit 0
47 END
48 cat > bar.test <<'END'
49 #! /bin/sh
50 echo "this is $0"
51 sleep '1'
52 exit 99
53 END
54 cat > baz.test <<'END'
55 #! /bin/sh
56 echo "this is $0"
57 exit 1
58 END
59 chmod a+x foo.test bar.test baz.test
60
61 $ACLOCAL
62 $AUTOCONF
63 $AUTOMAKE -a
64
65 ./configure
66
67 $MAKE check >stdout && { cat stdout; exit 1; }
68 cat stdout
69 count_test_results total=3 pass=1 fail=1 skip=0 xfail=0 xpass=0 error=1
70 test -f test-suite.log
71 cat test-suite.log
72 test $(grep -c '^FAIL:' test-suite.log) -eq 1
73 test $(grep -c '^ERROR:' test-suite.log) -eq 1
74 $EGREP '^(X?PASS|XFAIL|SKIP)' test-suite.log && exit 1
75 test -f baz.log
76 test -f bar.log
77 test -f foo.log
78
79 $MAKE clean
80 test ! -e baz.log
81 test ! -e bar.log
82 test ! -e foo.log
83 test ! -e test-suite.log
84
85 # Check dependencies: baz.test needs to run before bar.test,
86 # but foo.test is not needed.
87 # Note that this usage has a problem: the summary will only
88 # take bar.log into account, because the $(TEST_SUITE_LOG) rule
89 # does not "see" baz.log.  Hmm.
90 run_make -O -e FAIL TESTS='bar.test' check
91 grep '^FAIL: baz\.test$' stdout
92 grep '^ERROR: bar\.test$' stdout
93
94 test -f baz.log
95 test -f bar.log
96 test ! -e foo.log
97 test -f test-suite.log
98
99 # Upon a lazy rerun, foo.test should be run, but the others shouldn't.
100 # Note that the lazy rerun still exits with a failure, due to the previous
101 # test failures.
102 # Note that the previous test and this one taken together expose the timing
103 # issue that requires the check-TESTS rule to always remove TEST_SUITE_LOG
104 # before running the tests lazily.
105 run_make -O -e FAIL check RECHECK_LOGS=
106 test -f foo.log
107 grep '^PASS: foo\.test$' stdout
108 grep bar.test stdout && exit 1
109 grep baz.test stdout && exit 1
110 grep '^# PASS: *1$' stdout
111 grep '^# FAIL: *1$' stdout
112 grep '^# ERROR: *1$' stdout
113
114 # Now, explicitly retry with all test logs already updated, and ensure
115 # that the summary is still displayed.
116 run_make -O -e FAIL check RECHECK_LOGS=
117 grep foo.test stdout && exit 1
118 grep bar.test stdout && exit 1
119 grep baz.test stdout && exit 1
120 grep '^# PASS: *1$' stdout
121 grep '^# FAIL: *1$' stdout
122 grep '^# ERROR: *1$' stdout
123
124 # Lazily rerunning only foo should only rerun this one test.
125 run_make -O -e FAIL check RECHECK_LOGS=foo.log
126 grep foo.test stdout
127 grep bar.test stdout && exit 1
128 grep baz.test stdout && exit 1
129 grep '^# PASS: *1$' stdout
130 grep '^# FAIL: *1$' stdout
131 grep '^# ERROR: *1$' stdout
132
133 $MAKE clean
134 run_make -O -e FAIL TEST_LOGS=baz.log check
135 grep foo.test stdout && exit 1
136 grep bar.test stdout && exit 1
137 grep baz.test stdout
138
139 $MAKE clean
140 run_make -O -e FAIL TESTS=baz.test check
141 grep foo.test stdout && exit 1
142 grep bar.test stdout && exit 1
143 grep baz.test stdout
144
145 :