4872b0fc28
Also put the coverity params up top, with all other params.
134 строки
3.7 KiB
Bash
Исполняемый файл
134 строки
3.7 KiB
Bash
Исполняемый файл
#!/bin/sh
|
|
|
|
#####
|
|
#
|
|
# Configuration options
|
|
#
|
|
#####
|
|
|
|
# e-mail address to send results to
|
|
results_addr=testing@open-mpi.org
|
|
|
|
# svn repository uri
|
|
master_code_uri=https://github.com/open-mpi/ompi.git
|
|
master_raw_uri=https://raw.github.com/open-mpi/ompi
|
|
release_code_uri=https://github.com/open-mpi/ompi-release.git
|
|
release_raw_uri=https://raw.github.com/open-mpi/ompi-release
|
|
|
|
# where to put built tarballs
|
|
outputroot=/l/osl/www/www.open-mpi.org/nightly
|
|
|
|
# where to find the build script
|
|
script_uri=contrib/nightly/create_tarball.sh
|
|
|
|
# helper scripts dir
|
|
script_dir=/u/mpiteam/scripts
|
|
|
|
# The tarballs to make
|
|
if [ $# -eq 0 ] ; then
|
|
# We're no longer ever checking the 1.0 - 1.6 branches anymore
|
|
branches="master v1.8"
|
|
else
|
|
branches=$@
|
|
fi
|
|
|
|
# Build root - scratch space
|
|
build_root=/home/mpiteam/openmpi/nightly-tarball-build-root
|
|
|
|
# Coverity stuff
|
|
coverity_token=`cat $HOME/coverity/openmpi-token.txt`
|
|
coverity_configure_args="--enable-mpi-fortran --enable-mpi-java --enable-oshmem --enable-oshmem-fortran --enable-oshmem-java --with-mxm=/opt/mellanox/mxm --with-psm --with-usnic"
|
|
|
|
export PATH=$HOME/local/bin:$PATH
|
|
export LD_LIBRARY_PATH=$HOME/local/lib:$LD_LIBRARY_PATH
|
|
|
|
#####
|
|
#
|
|
# Actually do stuff
|
|
#
|
|
#####
|
|
|
|
# load the modules configuration
|
|
. /etc/profile.d/modules.sh
|
|
module use ~/modules
|
|
|
|
# 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
|
|
# Get the last tarball version that was made
|
|
prev_snapshot=`cat $outputroot/$branch/latest_snapshot.txt`
|
|
|
|
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"
|
|
wget --quiet --no-check-certificate --tries=10 $raw_uri/$branch/$script_uri -O $script
|
|
if test ! $? -eq 0 ; then
|
|
echo "wget of OMPI 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/ompi-$branch"
|
|
|
|
echo "=== Running script..."
|
|
./$script \
|
|
$build_root/$branch \
|
|
$results_addr \
|
|
$outputroot/$branch \
|
|
$code_uri \
|
|
$branch \
|
|
>/dev/null 2>&1
|
|
|
|
module unload autotools
|
|
echo "=== Done running script"
|
|
|
|
# Did the script generate a new tarball? If so, save it so that we can
|
|
# spawn the coverity checker on it afterwards. Only for this for the
|
|
# master (for now).
|
|
latest_snapshot=`cat $outputroot/$branch/latest_snapshot.txt`
|
|
if test "$prev_snapshot" != "$latest_snapshot" && \
|
|
test "$branch" = "master"; then
|
|
echo "$outputroot/$branch/openmpi-$latest_snapshot.tar.bz2" >> $pending_coverity
|
|
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.
|
|
${script_dir}/remove-old.pl 28 $build_root/$branch
|
|
done
|
|
|
|
# If we had any new snapshots to send to coverity, process them now
|
|
|
|
for tarball in `cat $pending_coverity`; do
|
|
$HOME/scripts/openmpi-nightly-coverity.pl \
|
|
--filename=$tarball \
|
|
--coverity-token=$coverity_token \
|
|
--verbose \
|
|
--logfile-dir=$HOME/coverity \
|
|
--make-args=-j8 \
|
|
--configure-args="$coverity_configure_args"
|
|
done
|
|
rm -f $pending_coverity |