13231
|
1 |
#!/usr/bin/env bash
|
|
2 |
#
|
|
3 |
# $Id$
|
|
4 |
# Author: Gerwin Klein, TU Muenchen
|
|
5 |
# License: GPL (GNU GENERAL PUBLIC LICENSE)
|
|
6 |
#
|
|
7 |
# DESCRIPTION: Run isatool makeall from specified distribution and settings.
|
|
8 |
# Send email if it fails.
|
|
9 |
|
|
10 |
## global settings
|
13246
|
11 |
MAILTO="kleing@in.tum.de test@jflex.de"
|
|
12 |
|
13232
|
13 |
LOGPREFIX=~/log
|
13231
|
14 |
|
13236
|
15 |
MASTERLOG=$LOGPREFIX/isatest.log
|
|
16 |
|
13320
|
17 |
TMP=/tmp/isatest-makeall.$$
|
|
18 |
|
|
19 |
MAIL=~/bin/pmail
|
|
20 |
|
13231
|
21 |
## diagnostics
|
|
22 |
|
|
23 |
PRG="$(basename "$0")"
|
|
24 |
|
|
25 |
function usage()
|
|
26 |
{
|
|
27 |
echo
|
|
28 |
echo "Usage: $PRG distributionpath settings1 [settings2 ...]"
|
|
29 |
echo
|
|
30 |
echo " Run isatool makeall from specified distribution and settings."
|
|
31 |
echo " Send email if it fails."
|
|
32 |
echo
|
|
33 |
exit 1
|
|
34 |
}
|
|
35 |
|
|
36 |
function fail()
|
|
37 |
{
|
|
38 |
echo "$1" >&2
|
|
39 |
exit 2
|
|
40 |
}
|
|
41 |
|
|
42 |
## main
|
|
43 |
|
|
44 |
# argument checking
|
|
45 |
|
|
46 |
[ "$1" = "-?" ] && usage
|
|
47 |
[ "$#" -lt "2" ] && usage
|
|
48 |
|
|
49 |
DISTPREFIX=$1
|
|
50 |
shift
|
|
51 |
|
|
52 |
[ -d $DISTPREFIX ] || fail "$DISTPREFIX is not a directory."
|
|
53 |
|
13320
|
54 |
LOGS=""
|
|
55 |
|
13231
|
56 |
for SETTINGS in $@; do
|
|
57 |
|
|
58 |
[ -r $SETTINGS ] || fail "Cannot read $SETTINGS."
|
|
59 |
|
|
60 |
|
|
61 |
# logfile setup
|
|
62 |
|
|
63 |
DATE=$(date "+%d-%b-%Y")
|
|
64 |
SHORT=${SETTINGS##*/}
|
|
65 |
TESTLOG=$LOGPREFIX/isatest-makeall-$SHORT-$DATE-$HOSTNAME.log
|
|
66 |
|
|
67 |
# the test
|
|
68 |
|
|
69 |
echo ------------------- starting test --- `date` --- $HOSTNAME > $TESTLOG 2>&1
|
|
70 |
|
13233
|
71 |
cat $SETTINGS >> $DISTPREFIX/Isabelle/etc/settings
|
13320
|
72 |
nice $DISTPREFIX/Isabelle/bin/isatool makeall -j 2 all >> $TESTLOG 2>&1
|
13231
|
73 |
|
|
74 |
if [ $? -eq 0 ]
|
|
75 |
then
|
13236
|
76 |
echo ------------------- test successful --- `date` --- $HOSTNAME >> $TESTLOG 2>&1
|
13231
|
77 |
gzip -f $TESTLOG
|
13246
|
78 |
rm -rf ~/isabelle-$SHORT
|
13231
|
79 |
else
|
|
80 |
echo ------------------- test FAILED --- `date` --- $HOSTNAME >> $TESTLOG 2>&1
|
13236
|
81 |
FAIL="$FAIL$SHORT "
|
13320
|
82 |
LOGS="${LOGS}$HOSTNAME:$TESTLOG\n"
|
13231
|
83 |
fi
|
|
84 |
|
|
85 |
done
|
|
86 |
|
13236
|
87 |
ELAPSED=$("$HOME/bin/showtime" "$SECONDS")
|
|
88 |
|
|
89 |
if [ "$FAIL" != "" ]; then
|
|
90 |
echo "$(date) $HOSTNAME $PRG: targets ${FAIL}FAILED, elapsed time $ELAPSED." >> $MASTERLOG
|
13320
|
91 |
|
|
92 |
echo "Test for platform(s) ${FAIL}failed. Log file(s) available at" > $TMP
|
|
93 |
echo "$LOGS" >> $TMP
|
|
94 |
|
|
95 |
for R in $MAILTO; do
|
|
96 |
$MAIL "isabelle test failed" $R $TMP
|
|
97 |
done
|
|
98 |
|
|
99 |
rm $TMP
|
|
100 |
|
13236
|
101 |
exit 1
|
|
102 |
else
|
|
103 |
echo "$(date) $HOSTNAME $PRG: all tests successful, elapsed time $ELAPSED." >> $MASTERLOG
|
|
104 |
fi
|
|
105 |
|
|
106 |
# end
|