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