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
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
|
#!/bin/sh
# Flags:
# --no-clean: don't make clean first, just carry on from
# a previous interrupted validation run
# --testsuite-only: don't build the compiler, just run
# the test suite
# --hpc: build stage2 with -fhpc, and see how much of the
# compiler the test suite covers.
# 2008-07-01: 63% slower than the default.
# HTML generated here: testsuite/hpc_output/hpc_index.html
# --fast: Default. Opposite to --slow.
# --slow: Build stage2 with -DDEBUG.
# 2008-07-01: 14% slower than the default.
set -e
no_clean=0
testsuite_only=0
hpc=NO
slow=NO
while [ $# -gt 0 ]
do
case "$1" in
--no-clean)
no_clean=1
;;
--testsuite-only)
testsuite_only=1
;;
--hpc)
hpc=YES
;;
--slow)
slow=YES
;;
--fast)
slow=NO
;;
*)
echo "Bad argument: $1" >&2
exit 1;;
esac
shift
done
if ! [ -d testsuite ]
then
echo 'You need the testsuite to validate' >&2
echo 'Run "./sync-all --testsuite get" to get it' >&2
exit 1
fi
if [ "$THREADS" = "" ]; then
if [ "$CPUS" = "" ]; then
threads=2
else
threads=$(($CPUS + 1)) # `expr $CPUS + 1`
fi
else
threads="$THREADS"
fi
if type gmake > /dev/null 2> /dev/null
then
make="gmake"
else
make="make"
fi
if [ $testsuite_only -eq 0 ]; then
if [ $no_clean -eq 0 ]; then
$make maintainer-clean NO_CLEAN_GMP=YES
INSTDIR=`pwd`/inst
if [ "$OSTYPE" = "cygwin" ]
then
INSTDIR=`cygpath -m "$INSTDIR"`
fi
/usr/bin/perl -w boot --validate --required-tag=dph
./configure --prefix="$INSTDIR" $config_args
fi
thisdir=`utils/ghc-pwd/dist-boot/ghc-pwd`
echo "Validating=YES" > mk/are-validating.mk
$make -j$threads ValidateHpc=$hpc ValidateSlow=$slow
# For a "debug make", add "--debug=b --debug=m"
$make binary-dist-prep
$make test_bindist TEST_PREP=YES
#
# Install the mtl package into the bindist, because it is used by some
# tests. It isn't essential that we do this (the failing tests will
# be treated as expected failures), but we get a bit more test
# coverage, and also verify that we can install a package into the
# bindist with Cabal.
#
bindistdir="bindisttest/install dir"
cd libraries/mtl
"$thisdir/$bindistdir/bin/ghc" --make Setup
./Setup configure --with-ghc="$thisdir/$bindistdir/bin/ghc" --with-haddock="$thisdir/$bindistdir/bin/haddock" --global --builddir=dist-bindist --prefix="$thisdir/$bindistdir"
./Setup build --builddir=dist-bindist
./Setup haddock --builddir=dist-bindist
./Setup install --builddir=dist-bindist
./Setup clean --builddir=dist-bindist
rm -f Setup Setup.exe Setup.hi Setup.o
cd $thisdir
fi # testsuite-only
if [ "$hpc" = YES ]
then
# XXX With threads we'd need to give a different tix file to each thread
# and then sum them up at the end
threads=1
HPCTIXFILE=$thisdir/testsuite/hpc_output/ghc.tix
export HPCTIXFILE
rm -f $HPCTIXFILE
fi
if [ "$slow" = YES ]
then
MAKE_TEST_TARGET=fulltest
else
MAKE_TEST_TARGET=test
fi
$make $MAKE_TEST_TARGET stage=2 BINDIST=YES THREADS=$threads 2>&1 | tee testlog
if [ "$hpc" = YES ]
then
utils/hpc/hpc markup --hpcdir=. --srcdir=compiler --srcdir=testsuite/hpc_output --destdir=testsuite/hpc_output testsuite/hpc_output/ghc.tix
fi
echo "-------------------------------------------------------------------"
if
grep '\<0 caused framework failures' testlog >/dev/null 2>/dev/null &&
grep '\<0 unexpected passes' testlog >/dev/null 2>/dev/null &&
grep '\<0 unexpected failures' testlog >/dev/null 2>/dev/null &&
! grep 'Some files are written by multiple tests' testlog >/dev/null 2>/dev/null ; then
if [ $testsuite_only -eq 0 ] && [ $no_clean -eq 0 ]
then
cat <<EOF
Congratulations! This tree has passed minimal testing.
NOTE: If you have made changes that may cause failures not tested for by
the minimal testing procedure, please do further testing as necessary.
When you are satisfied that you haven't broken anything, go ahead and
push/send your patches.
EOF
if [ -f mk/validate.mk ] && grep -q "^[^#]" mk/validate.mk
then
cat <<EOF
WARNING: You seem to have things set in mk/validate.mk. Please check
that it is OK before pushing.
EOF
fi
cat <<EOF
-------------------------------------------------------------------
EOF
else
cat <<EOF
I didn't find any problems, but this wasn't a complete validate run,
so be careful!
NOTE: If you have made changes that may cause failures not tested for by
the minimal testing procedure, please do further testing as necessary.
-------------------------------------------------------------------
EOF
fi
else
cat <<EOF
Oops! Looks like you have some unexpected test results or framework failures.
Please fix them before pushing/sending patches.
-------------------------------------------------------------------
EOF
exit 1
fi
|