File: parallel-tests-log-override-recheck.test

package info (click to toggle)
automake1.11 1%3A1.11.6-3
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 9,940 kB
  • ctags: 412
  • sloc: sh: 35,057; perl: 10,676; makefile: 938; ansic: 496
file content (92 lines) | stat: -rwxr-xr-x 1,987 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
#! /bin/sh
# Copyright (C) 2011 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: runtime redefinition of $(TEST_SUITE_LOG)
# for the recheck target.

parallel_tests=yes
. ./defs || Exit 1

set -e

cat >> configure.in <<'END'
AC_OUTPUT
END

cat > Makefile.am <<'END'
TESTS = foo.test bar.test baz.test
END

cat > foo.test <<'END'
#! /bin/sh
echo "this is $0"
exit 0
END

cat > bar.test <<'END'
#! /bin/sh
echo "this is $0"
exit 99
END

cat > baz.test <<'END'
#! /bin/sh
echo "this is $0"
exit ${BAZ_EXIT_STATUS-1}
END

chmod a+x *.test

unset BAZ_EXIT_STATUS || :

$ACLOCAL
$AUTOCONF
$AUTOMAKE -a

./configure
$MAKE check >stdout && { cat stdout; Exit 1; }
cat stdout

chmod a-rw test-suite.log
TEST_SUITE_LOG=my.log $MAKE -e recheck >stdout \
  && { cat stdout; Exit 1; }
cat stdout
ls -l
grep '^2 of 2 .*failed' stdout
for x in stdout my.log; do
  $FGREP foo.test $x && Exit 1
  $FGREP bar.test $x
  $FGREP baz.test $x
done

chmod a-rw my.log
BAZ_EXIT_STATUS=0 TEST_SUITE_LOG=my2.log $MAKE -e recheck >stdout \
  && { cat stdout; Exit 1; }
cat stdout
ls -l
grep '^1 of 2 .*failed' stdout
$FGREP foo.test stdout && Exit 1
$FGREP bar.test stdout
$FGREP baz.test stdout
$FGREP foo.test my2.log && Exit 1
$FGREP bar.test my2.log
$FGREP baz.test my2.log && Exit 1

chmod u+r test-suite.log my.log
$FGREP baz.test test-suite.log
$FGREP baz.test my.log

: