2004-07-15 05:28:07 +00:00
|
|
|
#!/bin/sh
|
|
|
|
#
|
|
|
|
# $HEADER$
|
|
|
|
#
|
|
|
|
# This script is used to make a nightly snapshot tarball of Open MPI.
|
|
|
|
#
|
|
|
|
# $1: scratch root
|
|
|
|
# $2: e-mail address for destination
|
|
|
|
# $3: SVN root
|
|
|
|
# $4: dest dir
|
|
|
|
#
|
|
|
|
|
|
|
|
scratch_root="$1"
|
|
|
|
email="$2"
|
|
|
|
svnroot="$3"
|
|
|
|
destdir="$4"
|
|
|
|
|
|
|
|
# Set this to any value for additional output; typically only when
|
|
|
|
# debugging
|
|
|
|
debug=
|
|
|
|
|
2004-07-15 11:36:17 +00:00
|
|
|
# do you want a success mail?
|
|
|
|
want_success_mail=1
|
|
|
|
|
2004-08-23 06:35:28 +00:00
|
|
|
# max length of logfile to send in an e-mail
|
|
|
|
max_log_len=50
|
|
|
|
|
2004-07-15 11:36:17 +00:00
|
|
|
# how many snapshots to keep in the destdir?
|
2004-07-15 19:16:24 +00:00
|
|
|
max_snapshots=5
|
2004-07-15 11:36:17 +00:00
|
|
|
|
|
|
|
############################################################################
|
|
|
|
# Shouldn't need to change below this line
|
|
|
|
############################################################################
|
|
|
|
|
2004-07-15 05:28:07 +00:00
|
|
|
start_time="`date`"
|
|
|
|
|
|
|
|
# Sanity checks
|
|
|
|
if test -z "$scratch_root" -o -z "$email" -o -z "$svnroot" \
|
|
|
|
-o -z "$destdir"; then
|
2004-07-15 11:59:27 +00:00
|
|
|
echo "Must specify scratch root directory, e-mail address, SVN root, and destination directory"
|
2004-07-15 05:28:07 +00:00
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
# send a mail
|
2004-07-15 19:16:24 +00:00
|
|
|
# should only be called after logdir is set
|
2004-07-15 13:53:44 +00:00
|
|
|
send_error_mail() {
|
2004-07-15 05:57:03 +00:00
|
|
|
outfile="$scratch_root/output.txt"
|
|
|
|
rm -f "$outfile"
|
|
|
|
touch "$outfile"
|
2004-07-15 19:16:24 +00:00
|
|
|
for file in `/bin/ls $logdir/* | sort`; do
|
2004-08-23 06:35:28 +00:00
|
|
|
len="`wc -l $file | awk '{ print $1}'`"
|
|
|
|
if test "`expr $len \> $max_log_len`" = "1"; then
|
|
|
|
echo "[... previous lines snipped ...]" >> "$outfile"
|
|
|
|
tail -$max_log_len "$file" >> "$outfile"
|
|
|
|
else
|
|
|
|
cat "$file" >> "$outfile"
|
|
|
|
fi
|
2004-07-15 05:57:03 +00:00
|
|
|
done
|
2004-08-29 12:42:46 +00:00
|
|
|
if test -n "$version"; then
|
2004-09-08 18:58:13 +00:00
|
|
|
Mail -s "=== CREATE FAILURE ($version) ===" "$email" < "$outfile"
|
2004-08-29 12:42:46 +00:00
|
|
|
else
|
2004-09-08 18:58:13 +00:00
|
|
|
Mail -s "=== CREATE FAILURE ===" "$email" < "$outfile"
|
2004-08-29 12:42:46 +00:00
|
|
|
fi
|
2004-07-15 05:57:03 +00:00
|
|
|
rm -f "$outfile"
|
2004-07-15 05:28:07 +00:00
|
|
|
}
|
|
|
|
|
2004-07-15 13:53:44 +00:00
|
|
|
# send output error message
|
|
|
|
die() {
|
|
|
|
msg="$*"
|
2004-07-15 19:16:24 +00:00
|
|
|
cat > "$logdir/00_announce.txt" <<EOF
|
2004-07-15 13:53:44 +00:00
|
|
|
Creating the nightly tarball ended in error:
|
|
|
|
|
|
|
|
$msg
|
|
|
|
EOF
|
|
|
|
send_error_mail
|
|
|
|
exit 1
|
|
|
|
}
|
|
|
|
|
2004-07-15 05:28:07 +00:00
|
|
|
# do the work
|
2004-07-15 19:16:24 +00:00
|
|
|
# should only be called after logdir is set
|
2004-07-15 05:28:07 +00:00
|
|
|
do_command() {
|
|
|
|
cmd="$*"
|
2004-07-15 19:16:24 +00:00
|
|
|
logfile="$logdir/20-command.txt"
|
2004-07-15 05:28:07 +00:00
|
|
|
rm -f "$logfile"
|
|
|
|
if test -n "$debug"; then
|
|
|
|
echo "*** Running command: $cmd"
|
2004-07-15 19:16:24 +00:00
|
|
|
eval $cmd > "$logfile" 2>&1
|
2004-07-15 05:28:07 +00:00
|
|
|
st=$?
|
|
|
|
echo "*** Command complete: exit status: $st"
|
|
|
|
else
|
|
|
|
eval $cmd > "$logfile" 2>&1
|
|
|
|
st=$?
|
|
|
|
fi
|
|
|
|
if test "$st" != "0"; then
|
2004-07-15 19:16:24 +00:00
|
|
|
cat > "$logdir/15-error.txt" <<EOF
|
2004-07-15 05:28:07 +00:00
|
|
|
|
|
|
|
ERROR: Command returned a non-zero exist status
|
|
|
|
$cmd
|
|
|
|
|
|
|
|
Start time: $start_time
|
|
|
|
End time: `date`
|
|
|
|
|
|
|
|
=======================================================================
|
|
|
|
EOF
|
2004-07-15 19:16:24 +00:00
|
|
|
cat > "$logdir/25-error.txt" <<EOF
|
2004-07-15 05:28:07 +00:00
|
|
|
=======================================================================
|
|
|
|
|
|
|
|
Your friendly daemon,
|
|
|
|
Cyrador
|
|
|
|
EOF
|
2004-07-15 13:53:44 +00:00
|
|
|
send_error_mail
|
|
|
|
exit 1
|
2004-07-15 05:28:07 +00:00
|
|
|
fi
|
|
|
|
rm -f "$logfile"
|
|
|
|
}
|
|
|
|
|
|
|
|
# see if the destination directory exists
|
|
|
|
if test ! -d "$destdir"; then
|
|
|
|
mkdir -p "$destdir"
|
|
|
|
fi
|
|
|
|
if test ! -d "$destdir"; then
|
2004-07-15 13:53:44 +00:00
|
|
|
die "Could not cd to dest dir: $destdir"
|
2004-07-15 05:28:07 +00:00
|
|
|
fi
|
|
|
|
|
2004-07-15 19:16:24 +00:00
|
|
|
# move into the scratch directory and ensure we have an absolute
|
|
|
|
# pathname for it
|
2004-07-15 05:28:07 +00:00
|
|
|
if test ! -d "$scratch_root"; then
|
|
|
|
mkdir -p "$scratch_root"
|
|
|
|
fi
|
|
|
|
if test ! -d "$scratch_root"; then
|
2004-07-15 13:53:44 +00:00
|
|
|
die "Could not cd to scratch root: $scratch_root"
|
2004-07-15 05:28:07 +00:00
|
|
|
fi
|
|
|
|
cd "$scratch_root"
|
2004-07-15 19:16:24 +00:00
|
|
|
scratch_root="`pwd`"
|
2004-07-15 05:28:07 +00:00
|
|
|
|
2004-07-15 19:16:24 +00:00
|
|
|
# get the snapshot number
|
|
|
|
svn co -N svn+ssh://svn.open-mpi.org/l/svn/ompi > /dev/null 2>&1
|
|
|
|
cd ompi
|
|
|
|
svnr="r`svn info . | egrep '^Revision: [0-9]+' | awk '{ print $2 }'`"
|
|
|
|
cd ..
|
|
|
|
rm -rf ompi
|
|
|
|
root="$scratch_root/create-$svnr"
|
|
|
|
rm -rf "$root"
|
|
|
|
mkdir "$root"
|
|
|
|
cd "$root"
|
|
|
|
|
|
|
|
# startup the logfile
|
|
|
|
logdir="$root/logs"
|
|
|
|
mkdir "$logdir"
|
2004-07-15 05:28:07 +00:00
|
|
|
|
|
|
|
# checkout a clean version
|
|
|
|
do_command "svn co $svnroot ompi"
|
|
|
|
|
|
|
|
# lets work on it
|
|
|
|
cd ompi
|
|
|
|
svnversion="`svnversion .`"
|
|
|
|
|
|
|
|
# autogen is our friend
|
|
|
|
do_command "./autogen.sh"
|
|
|
|
|
|
|
|
# do config
|
|
|
|
do_command "./configure --enable-dist"
|
|
|
|
|
|
|
|
# do make dist
|
|
|
|
do_command "make dist"
|
|
|
|
|
|
|
|
# move the resulting tarballs to the destdir
|
|
|
|
gz="`/bin/ls openmpi*tar.gz`"
|
|
|
|
bz2="`/bin/ls openmpi*tar.bz2`"
|
|
|
|
mv $gz $bz2 $destdir
|
|
|
|
cd $destdir
|
2004-07-15 13:53:44 +00:00
|
|
|
|
|
|
|
# make the latest_snapshot.txt file containing the last version
|
|
|
|
version="`echo $gz | sed -e 's/openmpi-\(.*\)\.tar\.gz/\1/g'`"
|
|
|
|
rm -f latest_snapshot.txt
|
|
|
|
echo $version > latest_snapshot.txt
|
|
|
|
|
|
|
|
# trim the destdir to $max_snapshots
|
2004-07-15 19:16:24 +00:00
|
|
|
for ext in gz bz2; do
|
|
|
|
count="`ls openmpi*.tar.$ext | wc -l | awk '{ print $1 }'`"
|
|
|
|
if test "`expr $count \> $max_snapshots`" = "1"; then
|
|
|
|
num_old="`expr $count - $max_snapshots`"
|
|
|
|
old="`ls -rt openmpi*.tar.$ext | head -$num_old`"
|
|
|
|
rm -f $old
|
|
|
|
fi
|
|
|
|
done
|
2004-07-15 05:28:07 +00:00
|
|
|
|
|
|
|
# generate md5 and sha1 sums
|
|
|
|
rm -f md5sums.txt sha1sums.txt
|
|
|
|
touch md5sums.txt sha1sums.txt
|
|
|
|
for file in `/bin/ls *gz *bz2 | grep -v latest`; do
|
|
|
|
md5sum $file >> md5sums.txt
|
|
|
|
sha1sum $file >> sha1sums.txt
|
|
|
|
done
|
|
|
|
|
2004-07-15 05:57:03 +00:00
|
|
|
# remove temp dirs
|
2004-07-15 19:16:24 +00:00
|
|
|
cd "$scratch_root"
|
|
|
|
rm -rf "$root"
|
2004-07-15 05:57:03 +00:00
|
|
|
|
2004-07-15 05:28:07 +00:00
|
|
|
# send success mail
|
2004-07-15 11:36:17 +00:00
|
|
|
if test "$want_success_mail" = "1"; then
|
2004-08-29 12:42:46 +00:00
|
|
|
Mail -s "Create success (r$version)" "$email" <<EOF
|
2004-07-15 19:16:24 +00:00
|
|
|
Creating nightly snapshot SVN tarball was a success.
|
2004-07-15 05:28:07 +00:00
|
|
|
|
2004-07-15 13:53:44 +00:00
|
|
|
Snapshot: $version
|
2004-07-15 05:28:07 +00:00
|
|
|
Start time: $start_time
|
|
|
|
End time: `date`
|
|
|
|
|
|
|
|
Your friendly daemon,
|
|
|
|
Cyrador
|
|
|
|
EOF
|
2004-07-15 11:36:17 +00:00
|
|
|
fi
|