2016-07-30 01:48:28 +03:00
|
|
|
#!/bin/sh
|
|
|
|
|
|
|
|
#####
|
|
|
|
#
|
|
|
|
# Configuration options
|
|
|
|
#
|
|
|
|
#####
|
|
|
|
|
|
|
|
# e-mail address to send results to
|
2016-08-20 17:32:06 +03:00
|
|
|
#results_addr=testing@lists.open-mpi.org
|
|
|
|
results_addr=rhc@open-mpi.org
|
2016-07-30 01:48:28 +03:00
|
|
|
|
2017-02-12 00:47:28 +03:00
|
|
|
# Set this to any value for additional output; typically only when
|
|
|
|
# debugging
|
|
|
|
: ${debug:=}
|
|
|
|
|
2016-07-30 01:48:28 +03:00
|
|
|
# svn repository uri
|
|
|
|
master_code_uri=https://github.com/pmix/master.git
|
|
|
|
master_raw_uri=https://raw.github.com/pmix/master
|
|
|
|
release_code_uri=https://github.com/pmix/releases.git
|
|
|
|
release_raw_uri=https://raw.github.com/pmix/releases
|
|
|
|
|
|
|
|
# where to put built tarballs
|
|
|
|
outputroot=$HOME/pmix/nightly
|
|
|
|
|
2017-01-20 19:40:38 +03:00
|
|
|
# Target where to scp the final tarballs
|
|
|
|
output_ssh_target=ompiteam@192.185.39.252
|
|
|
|
|
2016-07-30 01:48:28 +03:00
|
|
|
# where to find the build script
|
|
|
|
script_uri=contrib/nightly/create_tarball.sh
|
|
|
|
|
|
|
|
# helper scripts dir
|
2016-08-10 18:44:49 +03:00
|
|
|
script_dir=$HOME/ompi/contrib/build-server
|
2016-07-30 01:48:28 +03:00
|
|
|
|
|
|
|
# The tarballs to make
|
|
|
|
if [ $# -eq 0 ] ; then
|
|
|
|
branches="master"
|
|
|
|
else
|
|
|
|
branches=$@
|
|
|
|
fi
|
|
|
|
|
|
|
|
# Build root - scratch space
|
|
|
|
build_root=$HOME/pmix/nightly-tarball-build-root
|
|
|
|
|
|
|
|
# Coverity stuff
|
2016-10-14 18:40:05 +03:00
|
|
|
coverity_token=`cat $HOME/coverity/pmix-token.txt`
|
|
|
|
coverity_configure_args="--with-libevent=$HOME_PREFIX"
|
2016-07-30 01:48:28 +03:00
|
|
|
|
|
|
|
export PATH=$HOME_PREFIX/bin:$PATH
|
|
|
|
export LD_LIBRARY_PATH=$HOME_PREFIX/lib:$LD_LIBRARY_PATH
|
|
|
|
|
|
|
|
#####
|
|
|
|
#
|
|
|
|
# Actually do stuff
|
|
|
|
#
|
|
|
|
#####
|
|
|
|
|
2017-02-12 00:47:28 +03:00
|
|
|
debug() {
|
|
|
|
if test -n "$debug"; then
|
|
|
|
echo "=== DEBUG: $*"
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
run_command() {
|
|
|
|
debug "Running command: $*"
|
|
|
|
debug "Running in pwd: `pwd`"
|
|
|
|
if test -n "$debug"; then
|
|
|
|
eval $*
|
|
|
|
else
|
|
|
|
eval $* > /dev/null 2>&1
|
|
|
|
fi
|
|
|
|
|
|
|
|
if test $? -ne 0; then
|
|
|
|
echo "=== Command failed: $*"
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2016-07-30 01:48:28 +03:00
|
|
|
# load the modules configuration
|
|
|
|
. $MODULE_INIT
|
|
|
|
module use $AUTOTOOL_MODULE
|
|
|
|
|
|
|
|
# get our nightly build script
|
|
|
|
mkdir -p $build_root
|
|
|
|
cd $build_root
|
|
|
|
|
|
|
|
pending_coverity=$build_root/tarballs-to-run-through-coverity.txt
|
|
|
|
rm -f $pending_coverity
|
|
|
|
touch $pending_coverity
|
|
|
|
|
|
|
|
# Loop making the tarballs
|
|
|
|
module unload autotools
|
|
|
|
for branch in $branches; do
|
|
|
|
echo "=== Branch: $branch"
|
|
|
|
# Get the last tarball version that was made
|
|
|
|
prev_snapshot=`cat $outputroot/$branch/latest_snapshot.txt`
|
2017-02-09 19:56:00 +03:00
|
|
|
prev_snapshot_hash=`echo $prev_snapshot | cut -d- -f3`
|
|
|
|
echo "=== Previous snapshot: $prev_snapshot (hash: $prev_snapshot_hash)"
|
2016-07-30 01:48:28 +03:00
|
|
|
|
|
|
|
if test "$branch" = "master"; then
|
|
|
|
code_uri=$master_code_uri
|
|
|
|
raw_uri=$master_raw_uri
|
|
|
|
else
|
|
|
|
code_uri=$release_code_uri
|
|
|
|
raw_uri=$release_raw_uri
|
|
|
|
fi
|
|
|
|
|
|
|
|
# Form a URL-specific script name
|
|
|
|
script=$branch-`basename $script_uri`
|
|
|
|
|
|
|
|
echo "=== Getting script from: $raw_uri"
|
2017-02-12 00:47:28 +03:00
|
|
|
run_command wget --quiet --no-check-certificate --tries=10 $raw_uri/$branch/$script_uri -O $script
|
2016-07-30 01:48:28 +03:00
|
|
|
if test ! $? -eq 0 ; then
|
|
|
|
echo "wget of PMIX nightly tarball create script failed."
|
|
|
|
if test -f $script ; then
|
|
|
|
echo "Using older version of $script for this run."
|
|
|
|
else
|
|
|
|
echo "No build script available. Aborting."
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
chmod +x $script
|
|
|
|
|
|
|
|
module load "autotools/pmix-$branch"
|
2017-02-12 00:47:28 +03:00
|
|
|
# module load "libevent/pmix-$branch"
|
2016-07-30 01:48:28 +03:00
|
|
|
|
|
|
|
echo "=== Running script..."
|
2017-02-12 00:47:28 +03:00
|
|
|
run_command ./$script \
|
2016-07-30 01:48:28 +03:00
|
|
|
$build_root/$branch \
|
|
|
|
$results_addr \
|
|
|
|
$outputroot/$branch \
|
|
|
|
$code_uri \
|
2017-02-12 00:47:28 +03:00
|
|
|
$branch
|
2016-07-30 01:48:28 +03:00
|
|
|
|
|
|
|
module unload autotools
|
|
|
|
echo "=== Done running script"
|
|
|
|
|
2017-02-09 19:56:00 +03:00
|
|
|
# Did the script generate a new tarball? Ensure to compare the
|
|
|
|
# only the hash of the previous tarball and the hash of the new
|
|
|
|
# tarball (the filename also contains the date/timestamp, which
|
|
|
|
# will always be different).
|
|
|
|
|
|
|
|
# If so, save it so that we can spawn the coverity checker on it
|
|
|
|
# afterwards. Only for this for the master (for now).
|
2016-07-30 01:48:28 +03:00
|
|
|
latest_snapshot=`cat $outputroot/$branch/latest_snapshot.txt`
|
2017-02-09 19:56:00 +03:00
|
|
|
latest_snapshot_hash=`echo $latest_snapshot | cut -d- -f3`
|
|
|
|
echo "=== Latest snapshot: $latest_snapshot (hash: $latest_snapshot_hash)"
|
|
|
|
if test "$prev_snapshot_hash" = "$latest_snapshot_hash"; then
|
|
|
|
echo "=== Hash has not changed; no need to upload/save the new tarball"
|
|
|
|
else
|
2016-08-03 07:59:18 +03:00
|
|
|
if test "$branch" = "master"; then
|
|
|
|
echo "=== Saving output for a Coverity run"
|
|
|
|
echo "$outputroot/$branch/pmix-$latest_snapshot.tar.bz2" >> $pending_coverity
|
|
|
|
else
|
|
|
|
echo "=== NOT saving output for a Coverity run"
|
|
|
|
fi
|
|
|
|
echo "=== Posting tarball to open-mpi.org"
|
|
|
|
# tell the web server to cleanup old nightly tarballs
|
2017-02-12 00:47:28 +03:00
|
|
|
run_command ssh -p 2222 \
|
2017-01-20 19:40:38 +03:00
|
|
|
$output_ssh_target \
|
|
|
|
"git/ompi/contrib/build-server/remove-old.pl 7 public_html/software/pmix/nightly/$branch"
|
2016-08-03 07:59:18 +03:00
|
|
|
# upload the new ones
|
2017-02-12 00:47:28 +03:00
|
|
|
run_command scp -P 2222 \
|
2017-01-20 19:40:38 +03:00
|
|
|
$outputroot/$branch/pmix-$latest_snapshot.tar.* \
|
|
|
|
$output_ssh_target:public_html/software/pmix/nightly/$branch/
|
2017-02-12 00:47:28 +03:00
|
|
|
run_command scp -P 2222 \
|
2017-01-20 19:40:38 +03:00
|
|
|
$outputroot/$branch/latest_snapshot.txt \
|
|
|
|
$output_ssh_target:public_html/software/pmix/nightly/$branch/
|
2016-08-03 07:59:18 +03:00
|
|
|
# direct the web server to regenerate the checksums
|
2017-02-12 00:47:28 +03:00
|
|
|
run_command ssh -p 2222 \
|
2017-01-20 19:40:38 +03:00
|
|
|
$output_ssh_target \
|
|
|
|
"cd public_html/software/pmix/nightly/$branch && md5sum pmix* > md5sums.txt"
|
2017-02-12 00:47:28 +03:00
|
|
|
run_command ssh -p 2222 \
|
2017-01-20 19:40:38 +03:00
|
|
|
$output_ssh_target \
|
|
|
|
"cd public_html/software/pmix/nightly/$branch && sha1sum pmix* > sha1sums.txt"
|
2016-07-30 01:48:28 +03:00
|
|
|
fi
|
|
|
|
|
|
|
|
# Failed builds are not removed. But if a human forgets to come
|
|
|
|
# in here and clean up the old failed builds, we can accumulate
|
|
|
|
# many over time. So remove any old failed bbuilds that are over
|
|
|
|
# 4 weeks old.
|
2017-02-12 00:47:28 +03:00
|
|
|
run_command ${script_dir}/remove-old.pl 7 $build_root/$branch
|
2016-07-30 01:48:28 +03:00
|
|
|
done
|
|
|
|
|
|
|
|
# If we had any new snapshots to send to coverity, process them now
|
|
|
|
|
2016-08-10 18:44:49 +03:00
|
|
|
for tarball in `cat $pending_coverity`; do
|
|
|
|
echo "=== Submitting $tarball to Coverity..."
|
2017-02-12 00:47:28 +03:00
|
|
|
run_command ${script_dir}/pmix-nightly-coverity.pl \
|
2016-08-10 18:44:49 +03:00
|
|
|
--filename=$tarball \
|
|
|
|
--coverity-token=$coverity_token \
|
|
|
|
--verbose \
|
|
|
|
--logfile-dir=$HOME/coverity \
|
|
|
|
--make-args=-j8 \
|
|
|
|
--configure-args="$coverity_configure_args"
|
|
|
|
done
|
2016-07-30 01:48:28 +03:00
|
|
|
rm -f $pending_coverity
|