aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rwxr-xr-xtools/sfsnapshot92
1 files changed, 58 insertions, 34 deletions
diff --git a/tools/sfsnapshot b/tools/sfsnapshot
index 47421af4..5cbdfb43 100755
--- a/tools/sfsnapshot
+++ b/tools/sfsnapshot
@@ -2,55 +2,79 @@
# Butchered version of snapshot
# Can only run on the shell compile farm server
+# Will always create a snapshot of HEAD
+# If want multiple snapshots, just run with "sfsnapshot {branch} [branch2 ...]"
# Assumes:
# ssh setup to send to shell.sf.net and $CF without password prompt
# autconf and automake installed on shell cf at v 2.57 & 1.72 and in PATH
function die { echo $1; exit 1; }
+# This makes the distribution. Expects $1 as CVS tag, otherwise uses HEAD
+function make_dist {
+ if [[ -n $1 ]] ; then
+ cvs_rel=$1
+ v="$1-"
+ else
+ cvs_rel="HEAD"
+ v=""
+ fi
+
+ # Get compile server to do the work
+ # Variables will be expanded locally before being run on $CF
+ ssh $CF <<-EOF
+ set -x
+ PATH=$PATH
+ [[ ! -d $IN/$cvs_rel ]] && mkdir -p $IN/$cvs_rel
+ cd $IN/$cvs_rel
+ if [[ -d $PROJECT ]] ; then
+ cd $PROJECT
+ cvs update -r $cvs_rel
+ else
+ cvs -z3 -d:pserver:anonymous@cvs.sourceforge.net:/cvsroot/nagiosplug co -r $cvs_rel nagiosplug
+ cd $PROJECT
+ aclocal
+ autoheader
+ autoconf
+ automake
+ autoreconf
+ ./configure
+ fi
+
+ # Make the Nagiosplug dist tarball
+ VER=$v$DS VERSION=$v$DS REL=snapshot make -e dist
+
+ # End ssh
+ EOF
+}
+
# Set working variables
PROJECT=nagiosplug
IN=${HOME}/tmp_snapshot
OUT_SERVER="shell.sf.net"
-OUT="/home/groups/n/na/nagiosplug/htdocs/snapshot"
+#OUT="/home/groups/n/na/nagiosplug/htdocs/snapshot"
+OUT="~/test"
CF="usf-cf-x86-linux-2"
DS=`date -u +%Y%m%d%H%M`
-# Get compile server to do the work
-# Variables will be expanded locally before being run on $CF
-ssh $CF <<EOF
-PATH=$PATH
-[[ ! -d $IN ]] && mkdir -p $IN
-cd ${IN}
-if [[ -d $PROJECT ]] ; then
- cd $PROJECT
- rm -f configure.in
- cvs update
-else
- cvs -z3 -d:pserver:anonymous@cvs.sourceforge.net:/cvsroot/nagiosplug co nagiosplug
- cd $PROJECT
-fi
-
-sed 's/^VER=.*/VER=${DS}/;s/^REL=.*/REL=snapshot/' configure.in > configure.tmp
-mv configure.tmp configure.in
-aclocal
-autoheader
-autoconf
-automake
-autoreconf
-
-# Make the Nagiosplug dist tarball
-./configure
-make dist
-
-# End ssh
-EOF
+# Make dists for HEAD and any others in command parameters
+make_dist
+for i in $* ; do
+ make_dist $i
+done
# Check for *.gz files locally (expect NFS between cf shell server and $CF)
set -x
-cd $IN/$PROJECT
-ls *.gz > /dev/null 2>&1 || die "No file created"
+files=$(ls $IN/*/$PROJECT/*.gz 2>/dev/null)
+[[ -z $files ]] && die "No files created"
ssh $OUT_SERVER "rm -f $OUT/*.gz"
-scp *.gz $OUT_SERVER:$OUT
-rm -f *.gz
+scp $files $OUT_SERVER:$OUT
+
+# Create MD5 sum
+ssh $OUT_SERVER << EOF
+cd $OUT
+md5sum *.gz > MD5SUM
+EOF
+
+rm -f $files