Admin/isatest-makeall
author kleing
Fri, 25 Apr 2003 15:17:36 +0200
changeset 13924 09f6f2fefb25
parent 13901 af38553e61ee
child 13962 908f6776a59b
permissions -rwxr-xr-x
no need to be nice everywhere
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
13838
fe83f2231767 case distinction on host for makefile flags
isatest
parents: 13432
diff changeset
    11
MAILTO="kleing@in.tum.de nipkow@in.tum.de berghofe@in.tum.de schirmer@in.tum.de lp15@cam.ac.uk"
13246
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
13320
2c6ee189ae63 send email plaform independently
isatest
parents: 13246
diff changeset
    17
TMP=/tmp/isatest-makeall.$$
2c6ee189ae63 send email plaform independently
isatest
parents: 13246
diff changeset
    18
2c6ee189ae63 send email plaform independently
isatest
parents: 13246
diff changeset
    19
MAIL=~/bin/pmail
2c6ee189ae63 send email plaform independently
isatest
parents: 13246
diff changeset
    20
13231
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    21
## diagnostics
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    22
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    23
PRG="$(basename "$0")"
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    24
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    25
function usage()
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    26
{
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    27
  echo
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    28
  echo "Usage: $PRG distributionpath settings1 [settings2 ...]"
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    29
  echo
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    30
  echo "  Run isatool makeall from specified distribution and settings."
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    31
  echo "  Send email if it fails."
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    32
  echo
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    33
  exit 1
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    34
}
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    35
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    36
function fail()
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    37
{
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    38
  echo "$1" >&2
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    39
  exit 2
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    40
}
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    41
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    42
## main
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    43
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    44
# argument checking
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    45
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    46
[ "$1" = "-?" ] && usage
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    47
[ "$#" -lt "2" ] && usage
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    48
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    49
DISTPREFIX=$1
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    50
shift
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    51
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    52
[ -d $DISTPREFIX ] || fail "$DISTPREFIX is not a directory."
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    53
13924
09f6f2fefb25 no need to be nice everywhere
kleing
parents: 13901
diff changeset
    54
NICE=nice
09f6f2fefb25 no need to be nice everywhere
kleing
parents: 13901
diff changeset
    55
13838
fe83f2231767 case distinction on host for makefile flags
isatest
parents: 13432
diff changeset
    56
case $HOSTNAME in
fe83f2231767 case distinction on host for makefile flags
isatest
parents: 13432
diff changeset
    57
        atbroy51)
fe83f2231767 case distinction on host for makefile flags
isatest
parents: 13432
diff changeset
    58
	MFLAGS="-j 2"
fe83f2231767 case distinction on host for makefile flags
isatest
parents: 13432
diff changeset
    59
	# MFLAGS=""
13924
09f6f2fefb25 no need to be nice everywhere
kleing
parents: 13901
diff changeset
    60
  NICE=""
13838
fe83f2231767 case distinction on host for makefile flags
isatest
parents: 13432
diff changeset
    61
	;;
fe83f2231767 case distinction on host for makefile flags
isatest
parents: 13432
diff changeset
    62
fe83f2231767 case distinction on host for makefile flags
isatest
parents: 13432
diff changeset
    63
        atbroy31)
fe83f2231767 case distinction on host for makefile flags
isatest
parents: 13432
diff changeset
    64
        MFLAGS="-j 5"
fe83f2231767 case distinction on host for makefile flags
isatest
parents: 13432
diff changeset
    65
        ;;
fe83f2231767 case distinction on host for makefile flags
isatest
parents: 13432
diff changeset
    66
	
fe83f2231767 case distinction on host for makefile flags
isatest
parents: 13432
diff changeset
    67
	atbroy12)
fe83f2231767 case distinction on host for makefile flags
isatest
parents: 13432
diff changeset
    68
	MFLAGS="-j 5"
fe83f2231767 case distinction on host for makefile flags
isatest
parents: 13432
diff changeset
    69
	;;
fe83f2231767 case distinction on host for makefile flags
isatest
parents: 13432
diff changeset
    70
fe83f2231767 case distinction on host for makefile flags
isatest
parents: 13432
diff changeset
    71
	sunbroy2)
fe83f2231767 case distinction on host for makefile flags
isatest
parents: 13432
diff changeset
    72
	MFLAGS="-j 4"
fe83f2231767 case distinction on host for makefile flags
isatest
parents: 13432
diff changeset
    73
	;;
fe83f2231767 case distinction on host for makefile flags
isatest
parents: 13432
diff changeset
    74
13901
af38553e61ee use 2 processors on sunbroy1
kleing
parents: 13838
diff changeset
    75
	sunbroy1)
af38553e61ee use 2 processors on sunbroy1
kleing
parents: 13838
diff changeset
    76
	MFLAGS="-j 2"
af38553e61ee use 2 processors on sunbroy1
kleing
parents: 13838
diff changeset
    77
	;;
af38553e61ee use 2 processors on sunbroy1
kleing
parents: 13838
diff changeset
    78
13838
fe83f2231767 case distinction on host for makefile flags
isatest
parents: 13432
diff changeset
    79
   	*)
fe83f2231767 case distinction on host for makefile flags
isatest
parents: 13432
diff changeset
    80
	MFLAGS=""
fe83f2231767 case distinction on host for makefile flags
isatest
parents: 13432
diff changeset
    81
        ;;
fe83f2231767 case distinction on host for makefile flags
isatest
parents: 13432
diff changeset
    82
esac
fe83f2231767 case distinction on host for makefile flags
isatest
parents: 13432
diff changeset
    83
fe83f2231767 case distinction on host for makefile flags
isatest
parents: 13432
diff changeset
    84
fe83f2231767 case distinction on host for makefile flags
isatest
parents: 13432
diff changeset
    85
13320
2c6ee189ae63 send email plaform independently
isatest
parents: 13246
diff changeset
    86
LOGS=""
2c6ee189ae63 send email plaform independently
isatest
parents: 13246
diff changeset
    87
13231
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    88
for SETTINGS in $@; do
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    89
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    90
    [ -r $SETTINGS ] || fail "Cannot read $SETTINGS."
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    91
    
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    92
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    93
    # logfile setup
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    94
13432
470daa444967 - changed date format for proper lexicographical ordering
isatest
parents: 13359
diff changeset
    95
    DATE=$(date "+%Y-%m-%d")
13231
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    96
    SHORT=${SETTINGS##*/}
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    97
    TESTLOG=$LOGPREFIX/isatest-makeall-$SHORT-$DATE-$HOSTNAME.log
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    98
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
    99
    # the test
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
   100
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
   101
    echo ------------------- starting test --- `date` --- $HOSTNAME > $TESTLOG 2>&1
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
   102
13233
kleing
parents: 13232
diff changeset
   103
    cat $SETTINGS >> $DISTPREFIX/Isabelle/etc/settings
13924
09f6f2fefb25 no need to be nice everywhere
kleing
parents: 13901
diff changeset
   104
    $NICE $DISTPREFIX/Isabelle/bin/isatool makeall $MFLAGS all >> $TESTLOG 2>&1 
13231
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
   105
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
   106
    if [ $? -eq 0 ]
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
   107
    then
13236
568bc754d303 included masterlog file
isatest
parents: 13233
diff changeset
   108
        echo ------------------- test successful --- `date` --- $HOSTNAME >> $TESTLOG 2>&1
13231
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
   109
        gzip -f $TESTLOG
13246
e51efc2029e9 email sending
isatest
parents: 13236
diff changeset
   110
	rm -rf ~/isabelle-$SHORT
13231
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
   111
    else
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
   112
        echo ------------------- test FAILED --- `date` --- $HOSTNAME >> $TESTLOG 2>&1
13236
568bc754d303 included masterlog file
isatest
parents: 13233
diff changeset
   113
	FAIL="$FAIL$SHORT "
13432
470daa444967 - changed date format for proper lexicographical ordering
isatest
parents: 13359
diff changeset
   114
	LOGS="${LOGS}$TESTLOG "
13231
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
   115
    fi
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
   116
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
   117
done
cce28efb2600 for nightly test builds
kleing
parents:
diff changeset
   118
13236
568bc754d303 included masterlog file
isatest
parents: 13233
diff changeset
   119
ELAPSED=$("$HOME/bin/showtime" "$SECONDS")
568bc754d303 included masterlog file
isatest
parents: 13233
diff changeset
   120
568bc754d303 included masterlog file
isatest
parents: 13233
diff changeset
   121
if [ "$FAIL" != "" ]; then
568bc754d303 included masterlog file
isatest
parents: 13233
diff changeset
   122
	echo "$(date) $HOSTNAME $PRG: targets ${FAIL}FAILED, elapsed time $ELAPSED." >> $MASTERLOG
13320
2c6ee189ae63 send email plaform independently
isatest
parents: 13246
diff changeset
   123
	
2c6ee189ae63 send email plaform independently
isatest
parents: 13246
diff changeset
   124
	echo "Test for platform(s) ${FAIL}failed. Log file(s) available at" > $TMP
13432
470daa444967 - changed date format for proper lexicographical ordering
isatest
parents: 13359
diff changeset
   125
	for L in $LOGS; do 
470daa444967 - changed date format for proper lexicographical ordering
isatest
parents: 13359
diff changeset
   126
		echo "$HOSTNAME:$L" >> $TMP 
470daa444967 - changed date format for proper lexicographical ordering
isatest
parents: 13359
diff changeset
   127
		echo "[...]" >> $TMP
470daa444967 - changed date format for proper lexicographical ordering
isatest
parents: 13359
diff changeset
   128
		tail -3 $L >> $TMP
470daa444967 - changed date format for proper lexicographical ordering
isatest
parents: 13359
diff changeset
   129
		echo >> $TMP
470daa444967 - changed date format for proper lexicographical ordering
isatest
parents: 13359
diff changeset
   130
	done
470daa444967 - changed date format for proper lexicographical ordering
isatest
parents: 13359
diff changeset
   131
	echo "Have a nice day," >> $TMP
470daa444967 - changed date format for proper lexicographical ordering
isatest
parents: 13359
diff changeset
   132
	echo "  isatest" >> $TMP
13320
2c6ee189ae63 send email plaform independently
isatest
parents: 13246
diff changeset
   133
2c6ee189ae63 send email plaform independently
isatest
parents: 13246
diff changeset
   134
        for R in $MAILTO; do
2c6ee189ae63 send email plaform independently
isatest
parents: 13246
diff changeset
   135
	    $MAIL "isabelle test failed" $R $TMP
2c6ee189ae63 send email plaform independently
isatest
parents: 13246
diff changeset
   136
	done
2c6ee189ae63 send email plaform independently
isatest
parents: 13246
diff changeset
   137
2c6ee189ae63 send email plaform independently
isatest
parents: 13246
diff changeset
   138
	rm $TMP
2c6ee189ae63 send email plaform independently
isatest
parents: 13246
diff changeset
   139
13236
568bc754d303 included masterlog file
isatest
parents: 13233
diff changeset
   140
	exit 1
568bc754d303 included masterlog file
isatest
parents: 13233
diff changeset
   141
else
568bc754d303 included masterlog file
isatest
parents: 13233
diff changeset
   142
        echo "$(date) $HOSTNAME $PRG: all tests successful, elapsed time $ELAPSED." >> $MASTERLOG
568bc754d303 included masterlog file
isatest
parents: 13233
diff changeset
   143
fi
568bc754d303 included masterlog file
isatest
parents: 13233
diff changeset
   144
568bc754d303 included masterlog file
isatest
parents: 13233
diff changeset
   145
# end