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 |
|
13231
|
17 |
## diagnostics
|
|
18 |
|
|
19 |
PRG="$(basename "$0")"
|
|
20 |
|
|
21 |
function usage()
|
|
22 |
{
|
|
23 |
echo
|
|
24 |
echo "Usage: $PRG distributionpath settings1 [settings2 ...]"
|
|
25 |
echo
|
|
26 |
echo " Run isatool makeall from specified distribution and settings."
|
|
27 |
echo " Send email if it fails."
|
|
28 |
echo
|
|
29 |
exit 1
|
|
30 |
}
|
|
31 |
|
|
32 |
function fail()
|
|
33 |
{
|
|
34 |
echo "$1" >&2
|
|
35 |
exit 2
|
|
36 |
}
|
|
37 |
|
|
38 |
## main
|
|
39 |
|
|
40 |
# argument checking
|
|
41 |
|
|
42 |
[ "$1" = "-?" ] && usage
|
|
43 |
[ "$#" -lt "2" ] && usage
|
|
44 |
|
|
45 |
DISTPREFIX=$1
|
|
46 |
shift
|
|
47 |
|
|
48 |
[ -d $DISTPREFIX ] || fail "$DISTPREFIX is not a directory."
|
|
49 |
|
|
50 |
for SETTINGS in $@; do
|
|
51 |
|
|
52 |
[ -r $SETTINGS ] || fail "Cannot read $SETTINGS."
|
|
53 |
|
|
54 |
|
|
55 |
# logfile setup
|
|
56 |
|
|
57 |
DATE=$(date "+%d-%b-%Y")
|
|
58 |
SHORT=${SETTINGS##*/}
|
|
59 |
TESTLOG=$LOGPREFIX/isatest-makeall-$SHORT-$DATE-$HOSTNAME.log
|
|
60 |
|
|
61 |
# the test
|
|
62 |
|
|
63 |
echo ------------------- starting test --- `date` --- $HOSTNAME > $TESTLOG 2>&1
|
|
64 |
|
13233
|
65 |
cp $DISTPREFIX/Isabelle/etc/settings $DISTPREFIX/Isabelle/etc/settings.save-$SHORT
|
|
66 |
cat $SETTINGS >> $DISTPREFIX/Isabelle/etc/settings
|
13231
|
67 |
$DISTPREFIX/Isabelle/bin/isatool makeall all >> $TESTLOG 2>&1
|
|
68 |
|
|
69 |
if [ $? -eq 0 ]
|
|
70 |
then
|
13236
|
71 |
echo ------------------- test successful --- `date` --- $HOSTNAME >> $TESTLOG 2>&1
|
|
72 |
mv $DISTPREFIX/Isabelle/etc/settings.save-$SHORT $DISTPREFIX/Isabelle/etc/settings
|
13231
|
73 |
gzip -f $TESTLOG
|
13246
|
74 |
rm -rf ~/isabelle-$SHORT
|
13231
|
75 |
else
|
|
76 |
echo ------------------- test FAILED --- `date` --- $HOSTNAME >> $TESTLOG 2>&1
|
13236
|
77 |
FAIL="$FAIL$SHORT "
|
13246
|
78 |
for R in $MAILTO; do
|
|
79 |
mail -t $R <<EOM
|
|
80 |
Subject: isabelle test failed
|
|
81 |
|
|
82 |
Test for platform $SHORT failed. Log file available at
|
|
83 |
|
|
84 |
$HOSTNAME:$TESTLOG
|
|
85 |
EOM
|
|
86 |
done
|
13231
|
87 |
# more action here
|
|
88 |
fi
|
|
89 |
|
|
90 |
done
|
|
91 |
|
13236
|
92 |
ELAPSED=$("$HOME/bin/showtime" "$SECONDS")
|
|
93 |
|
|
94 |
if [ "$FAIL" != "" ]; then
|
|
95 |
echo "$(date) $HOSTNAME $PRG: targets ${FAIL}FAILED, elapsed time $ELAPSED." >> $MASTERLOG
|
|
96 |
exit 1
|
|
97 |
else
|
|
98 |
echo "$(date) $HOSTNAME $PRG: all tests successful, elapsed time $ELAPSED." >> $MASTERLOG
|
|
99 |
fi
|
|
100 |
|
|
101 |
# end
|