Admin/isatest-makeall
author isatest
Sat, 30 Apr 2005 13:09:38 +0200
changeset 15897 86d510b0e4b7
parent 15888 64533471eec4
child 16095 f6af6b265d20
permissions -rwxr-xr-x
export DISTPREFIX to devel page Makefile
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
#
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
     6
# DESCRIPTION: Run isatool makeall from specified distribution and settings.
13962
908f6776a59b use /usr/stud/isatest as home for all platforms (macbroy33 has no /home/stud/..)
kleing
parents: 13924
diff changeset
     7
13231
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
     8
## global settings
13246
e51efc2029e9 email sending
isatest
parents: 13236
diff changeset
     9
13985
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
    10
# canoncical home for all platforms 
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
    11
HOME=/usr/stud/isatest
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
    12
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
    13
# where the log files are
13962
908f6776a59b use /usr/stud/isatest as home for all platforms (macbroy33 has no /home/stud/..)
kleing
parents: 13924
diff changeset
    14
LOGPREFIX=$HOME/log
13236
568bc754d303 included masterlog file
isatest
parents: 13233
diff changeset
    15
MASTERLOG=$LOGPREFIX/isatest.log
14035
c46ce87960fb attach log files
kleing
parents: 14012
diff changeset
    16
ERRORDIR=$HOME/var
c46ce87960fb attach log files
kleing
parents: 14012
diff changeset
    17
ERRORLOG=$ERRORDIR/error.log
13236
568bc754d303 included masterlog file
isatest
parents: 13233
diff changeset
    18
13985
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
    19
# where to put test-is-running files
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
    20
RUNNING=$HOME/var/running
13320
2c6ee189ae63 send email plaform independently
isatest
parents: 13246
diff changeset
    21
15888
64533471eec4 put 8h time limit on test
kleing
parents: 14981
diff changeset
    22
# max time until test is aborted (in sec)
64533471eec4 put 8h time limit on test
kleing
parents: 14981
diff changeset
    23
MAXTIME=28800
13320
2c6ee189ae63 send email plaform independently
isatest
parents: 13246
diff changeset
    24
13231
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    25
## diagnostics
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    26
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    27
PRG="$(basename "$0")"
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    28
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    29
function usage()
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    30
{
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    31
  echo
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    32
  echo "Usage: $PRG distributionpath settings1 [settings2 ...]"
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    33
  echo
13985
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
    34
  echo "  Runs isatool makeall from specified distribution and settings."
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
    35
  echo "  Leaves messages in ${ERRORLOG} and ${LOGPREFIX} if it fails."
13231
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    36
  echo
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    37
  exit 1
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    38
}
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    39
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    40
function fail()
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    41
{
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    42
  echo "$1" >&2
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    43
  exit 2
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    44
}
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    45
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    46
## main
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    47
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    48
# argument checking
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    49
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    50
[ "$1" = "-?" ] && usage
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    51
[ "$#" -lt "2" ] && usage
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    52
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    53
DISTPREFIX=$1
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    54
shift
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    55
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    56
[ -d $DISTPREFIX ] || fail "$DISTPREFIX is not a directory."
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    57
13985
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
    58
# make file flags and nice setup for different target platforms
13838
fe83f2231767 case distinction on host for makefile flags
isatest
parents: 13432
diff changeset
    59
case $HOSTNAME in
13985
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
    60
    atbroy51)
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
    61
        # 2 processors
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
    62
        MFLAGS="-j 2"
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
    63
        # MFLAGS=""
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
    64
        NICE=""
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
    65
        ;;
13838
fe83f2231767 case distinction on host for makefile flags
isatest
parents: 13432
diff changeset
    66
13985
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
    67
    atbroy31)
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
    68
        # cluster
13838
fe83f2231767 case distinction on host for makefile flags
isatest
parents: 13432
diff changeset
    69
        MFLAGS="-j 5"
fe83f2231767 case distinction on host for makefile flags
isatest
parents: 13432
diff changeset
    70
        ;;
13985
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
    71
  
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
    72
    sunbroy2)
13990
kleing
parents: 13987
diff changeset
    73
        MFLAGS="-j 6"
14012
9d1f027eb4e8 be nice on sunbroy2
kleing
parents: 13994
diff changeset
    74
	NICE="nice"
13985
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
    75
        ;;
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
    76
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
    77
    sunbroy1)
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
    78
        MFLAGS="-j 2"
14012
9d1f027eb4e8 be nice on sunbroy2
kleing
parents: 13994
diff changeset
    79
	NICE="nice"
13985
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
    80
        ;;
13838
fe83f2231767 case distinction on host for makefile flags
isatest
parents: 13432
diff changeset
    81
13985
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
    82
    macbroy*)
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
    83
        MFLAGS=""
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
    84
        NICE=""
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
    85
        ;;
13838
fe83f2231767 case distinction on host for makefile flags
isatest
parents: 13432
diff changeset
    86
13985
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
    87
    *)
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
    88
        MFLAGS=""
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
    89
        # be nice by default
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
    90
        NICE=nice
13838
fe83f2231767 case distinction on host for makefile flags
isatest
parents: 13432
diff changeset
    91
        ;;
fe83f2231767 case distinction on host for makefile flags
isatest
parents: 13432
diff changeset
    92
esac
fe83f2231767 case distinction on host for makefile flags
isatest
parents: 13432
diff changeset
    93
13985
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
    94
# main test loop
13320
2c6ee189ae63 send email plaform independently
isatest
parents: 13246
diff changeset
    95
13231
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    96
for SETTINGS in $@; do
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    97
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    98
    [ -r $SETTINGS ] || fail "Cannot read $SETTINGS."
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    99
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
   100
    # logfile setup
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
   101
13432
470daa444967 - changed date format for proper lexicographical ordering
isatest
parents: 13359
diff changeset
   102
    DATE=$(date "+%Y-%m-%d")
13231
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
   103
    SHORT=${SETTINGS##*/}
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
   104
    TESTLOG=$LOGPREFIX/isatest-makeall-$SHORT-$DATE-$HOSTNAME.log
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
   105
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
   106
    # the test
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
   107
13987
kleing
parents: 13985
diff changeset
   108
    touch $RUNNING/$SHORT.running
13985
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
   109
13231
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
   110
    echo ------------------- starting test --- `date` --- $HOSTNAME > $TESTLOG 2>&1
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
   111
13233
kleing
parents: 13232
diff changeset
   112
    cat $SETTINGS >> $DISTPREFIX/Isabelle/etc/settings
15888
64533471eec4 put 8h time limit on test
kleing
parents: 14981
diff changeset
   113
    (ulimit -t $MAXTIME; $NICE $DISTPREFIX/Isabelle/bin/isatool makeall $MFLAGS all >> $TESTLOG 2>&1)
13231
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
   114
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
   115
    if [ $? -eq 0 ]
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
   116
    then
13985
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
   117
        # test log and cleanup
13236
568bc754d303 included masterlog file
isatest
parents: 13233
diff changeset
   118
        echo ------------------- test successful --- `date` --- $HOSTNAME >> $TESTLOG 2>&1
13231
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
   119
        gzip -f $TESTLOG
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
   120
    else
13985
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
   121
        # test log
13231
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
   122
        echo ------------------- test FAILED --- `date` --- $HOSTNAME >> $TESTLOG 2>&1
13985
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
   123
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
   124
        # error log
14035
c46ce87960fb attach log files
kleing
parents: 14012
diff changeset
   125
        echo "Test for platform ${SHORT} failed. Log file attached." >> $ERRORLOG
13985
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
   126
        echo "[...]" >> $ERRORLOG
14035
c46ce87960fb attach log files
kleing
parents: 14012
diff changeset
   127
        tail -3 $TESTLOG >> $ERRORLOG
13985
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
   128
        echo >> $ERRORLOG
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
   129
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
   130
        FAIL="$FAIL$SHORT "
14035
c46ce87960fb attach log files
kleing
parents: 14012
diff changeset
   131
        (cd $ERRORDIR; ln -s $TESTLOG)
13231
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
   132
    fi
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
   133
13987
kleing
parents: 13985
diff changeset
   134
    rm -f $RUNNING/$SHORT.running
13231
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
   135
done
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
   136
13985
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
   137
# time and success/failure to master log
13236
568bc754d303 included masterlog file
isatest
parents: 13233
diff changeset
   138
ELAPSED=$("$HOME/bin/showtime" "$SECONDS")
568bc754d303 included masterlog file
isatest
parents: 13233
diff changeset
   139
13985
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
   140
if [ -z "$FAIL" ]; then
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
   141
    echo "$(date) $HOSTNAME $PRG: all tests successful, elapsed time $ELAPSED." >> $MASTERLOG
13236
568bc754d303 included masterlog file
isatest
parents: 13233
diff changeset
   142
else
13985
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
   143
    echo "$(date) $HOSTNAME $PRG: targets ${FAIL}FAILED, elapsed time $ELAPSED." >> $MASTERLOG
3852929a8d1d leave error messages in error.log, send only one email for all platforms
kleing
parents: 13962
diff changeset
   144
    exit 1
13236
568bc754d303 included masterlog file
isatest
parents: 13233
diff changeset
   145
fi
568bc754d303 included masterlog file
isatest
parents: 13233
diff changeset
   146
568bc754d303 included masterlog file
isatest
parents: 13233
diff changeset
   147
# end