Update master of plcapi.
[build.git] / vtest-nightly.sh
index 6a0a566..b50e621 100644 (file)
@@ -1,5 +1,5 @@
 #!/bin/bash
-REVISION=$(echo '$Revision: 7654 $' | sed -e 's,\$,,g' -e 's,^\w*:\s,,' )
+REVISION=$(echo '$Revision$' | sed -e 's,\$,,g' -e 's,^\w*:\s,,' )
 
 COMMANDPATH=$0
 COMMAND=$(basename $0)
@@ -15,6 +15,12 @@ DEFAULT_WEBPATH="/build/@PLDISTRO@/"
 DEFAULT_BUILDREPO="http://build.planet-lab.org/install-rpms/archive/"
 DEFAULT_REPOURL="@BUILDREPO@/@PLDISTRO@/@FCDISTRO@/@DATE@--@PLDISTRO@-@FCDISTRO@-@PERSONALITY@/RPMS"
 
+# 10.1 subnet allocated for testing at Princeton
+DEFAULT_IPPREFIX16="10.1"
+
+# default to eth0
+DEFAULT_TESTVSERVER_DEV=0
+
 # for the test part
 TESTSVNPATH="http://svn.planet-lab.org/svn/tests/trunk/system/"
 
@@ -68,24 +74,31 @@ function show_env () {
 }
 
 function usage () {
+    ### set BASE from DISTRO, if unspecified
     echo "Usage: $COMMAND [option] make-targets"
     echo "This is $REVISION"
     echo "Supported options"
     echo " -n dry-run : -n passed to make - vserver gets created though - no mail sent"
     echo " -f fcdistro - defaults to $DEFAULT_FCDISTRO"
     echo " -d pldistro - defaults to $DEFAULT_PLDISTRO"
-    echo " -p personality - defaults to $DEFAULT_PERSONALITY"
     echo " -b base - defaults to $DEFAULT_BASE"
-    echo "    @NAME@ replaced as appropriate"
+    echo "    @NAME@ replaced as appropriate, which currently defaults to $BASE"
+    echo " -p personality - defaults to $DEFAULT_PERSONALITY"
     echo " -t pldistrotags - defaults to \${PLDISTRO}-tags.mk"
     echo " -r tagsrelease - a release number that refers to PLDISTROTAGS - defaults to HEAD"
     echo " -s svnpath - where to fetch the build module"
     echo " -o : overwrite - re-run in base directory, do not create vserver"
     echo " -m mailto"
     echo " -a makevar=value - space in values are not supported"
+    echo " -u repourl -- defaults to $DEFAULT_REPOURL"
+    echo "    @NAME@ replaced as appropriate, which currently defaults to $REPOURL"
     echo " -w webpath - defaults to $DEFAULT_WEBPATH"
+    echo "    @NAME@ replaced as appropriate, which currently defaults to $WEBPATH"
+    echo " -j ip address ; use this to give the vserver an explicit IP address; also see -i."
+    echo " -i /16 ip subnet for auto IP address selection within the subnet -- defaults to $DEFAULT_IPPREFIX16"
+    echo "    This is only used when no explicit IP address is specified."
     echo " -v : be verbose"
-    echo " -7 : uses weekday-@FCDISTRO@ as base"
+    echo " -7 : uses weekday-@FCDISTRO@ as base -- defaults to $(date +%a|tr A-Z a-z)-$FCDISTRO"
     exit 1
 }
 
@@ -97,23 +110,39 @@ function main () {
     declare -a argv
     for arg in "$@"; do argv=(${argv[@]} "$arg") ; done
     
+    # set defaults
+    [ -z "$FCDISTRO" ] && FCDISTRO=$DEFAULT_FCDISTRO
+    [ -z "$PLDISTRO" ] && PLDISTRO=$DEFAULT_PLDISTRO
+    [ -z "$PERSONALITY" ] && PERSONALITY=$DEFAULT_PERSONALITY
+    [ -z "$PLDISTROTAGS" ] && PLDISTROTAGS="${PLDISTRO}-tags.mk"
+    [ -z "$BASE" ] && BASE="$DEFAULT_BASE"
+    [ -z "$WEBPATH" ] && WEBPATH="$DEFAULT_WEBPATH"
+    [ -z "$SVNPATH" ] && SVNPATH="$DEFAULT_SVNPATH"
+    [ -z "$BUILDREPO" ] && BUILDREPO="$DEFAULT_BUILDREPO"
+    [ -z "$REPOURL" ] && REPOURL="$DEFAULT_REPOURL"
+    [ -z "$IPPREFIX16" ] && IPPREFIX16="$DEFAULT_IPPREFIX16"
+    [ -z "$TESTVSERVER_DEV" ] && TESTVSERVER_DEV="$DEFAULT_TESTVSERVER_DEV"
+
     # parse arguments
     MAKEVARS=()
     MAKEOPTS=()
-    while getopts "nf:d:b:p:t:r:s:om:a:w:vh7" opt ; do
+    while getopts "nf:d:b:p:t:r:s:om:a:u:w:i:j:vh7" opt ; do
        case $opt in
-           n) DRY_RUN="true" ; MAKEOPTS=(${MAKEOPTS[@]} -n) ;;
+           n) DRY_RUN="true" ; MAKEOPTS=(${MAKEOPTS[@]} -n) ; MAILTO="";;
            f) FCDISTRO=$OPTARG ;;
            d) PLDISTRO=$OPTARG ;;
-           p) PERSONALITY=$OPTARG ;;
            b) BASE=$OPTARG ;;
+           p) PERSONALITY=$OPTARG ;;
            t) PLDISTROTAGS=$OPTARG ;;
            r) TAGSRELEASE=$OPTARG ;;
            s) SVNPATH=$OPTARG ;;
            o) OVERWRITEMODE=true ;;
            m) MAILTO=$OPTARG ;;
            a) MAKEVARS=(${MAKEVARS[@]} "$OPTARG") ;;
+           u) REPOURL=$OPTARG ;;
            w) WEBPATH=$OPTARG ;;
+           i) IPPREFIX16=$OPTARG ;;
+           j) TESTVSERVER_IP=$OPTARG ;;
            v) set -x ;;
            7) BASE="$(date +%a|tr A-Z a-z)-@FCDISTRO@" ;;
            h|*) usage ;;
@@ -123,19 +152,6 @@ function main () {
     shift $(($OPTIND - 1))
     MAKETARGETS="$@"
     
-    # set defaults
-    [ -z "$FCDISTRO" ] && FCDISTRO=$DEFAULT_FCDISTRO
-    [ -z "$PLDISTRO" ] && PLDISTRO=$DEFAULT_PLDISTRO
-    [ -z "$PERSONALITY" ] && PERSONALITY=$DEFAULT_PERSONALITY
-    [ -z "$PLDISTROTAGS" ] && PLDISTROTAGS="${PLDISTRO}-tags.mk"
-    [ -z "$BASE" ] && BASE="$DEFAULT_BASE"
-    [ -z "$WEBPATH" ] && WEBPATH="$DEFAULT_WEBPATH"
-    [ -z "$SVNPATH" ] && SVNPATH="$DEFAULT_SVNPATH"
-    [ -z "$BUILDREPO" ] && BUILDREPO="$DEFAULT_BUILDREPO"
-    [ -z "$REPOURL" ] && REPOURL="$DEFAULT_REPOURL"
-
-    [ -n "$DRY_RUN" ] && MAILTO=""
-       
     ### set BASE from DISTRO, if unspecified
     sedargs="-e s,@DATE@,${DATE},g -e s,@FCDISTRO@,${FCDISTRO},g -e s,@PLDISTRO@,${PLDISTRO},g -e s,@PERSONALITY@,${PERSONALITY},g"
     BASE=$(echo ${BASE} | sed $sedargs)
@@ -171,22 +187,20 @@ function main () {
     svn export $SVNPATH $tmpdir
     # Create vserver
     cd $tmpdir
-    ./vtest-init-vserver.sh -f ${FCDISTRO} -d ${PLDISTRO} -p ${PERSONALITY} ${BASE} ${REPOURL}
+    ./vtest-init-vserver.sh -i eth${TESTVSERVER_DEV} -f ${FCDISTRO} -d ${PLDISTRO} -p ${PERSONALITY} ${BASE} ${REPOURL}
     # cleanup
     cd -
     rm -rf $tmpdir
 
     vserver ${BASE} stop
     rm -f /etc/vservers/${BASE}/interfaces/0/*
-    [ -z "${TESTVSERVER_IP}" ] && TESTVSERVER_DEV="eth0"
-    if [ -z "${TESTVSERVER_IP}" ] ; then
+    if [ -z "$TESTVSERVER_IP" ] ; then
        xid=$(cat /etc/vservers/${BASE}/context)
-       class_a=10
-       class_b=201
-       TESTVSERVER_IP=$(python -c "context=int($xid); print '%d.%d.%d.%d' % ($class_a,$class_b,(context&0xff00)>>8,context&0xff)")
+       TESTVSERVER_IP=$(python -c "context=int($xid); print '%s.%d.%d' % ($IPPREFIX16,(context&0xff00)>>8,context&0xff)")
     fi
+    mkdir -p /etc/vservers/${BASE}/interfaces/0
     echo "${TESTVSERVER_IP}" > /etc/vservers/${BASE}/interfaces/0/ip
-    echo "${TESTVSERVER_DEV}" > /etc/vservers/${BASE}/interfaces/0/dev
+    echo "eth${TESTVSERVER_DEV}" > /etc/vservers/${BASE}/interfaces/0/dev
     vserver ${BASE} start
     echo "XXXXXXXXXX $COMMAND: preparation of vserver $BASE done" $(date)
 
@@ -204,7 +218,7 @@ function main () {
 
     svn cat ${TESTSVNPATH}/selftest > /vservers/${BASE}/selftest
     vserver ${BASE} exec chmod +x /selftest
-    vserver ${BASE} exec /selftest
+    vserver ${BASE} exec /selftest ${BASE}.$(hostname) ${TESTVSERVER_IP}
     success 
 }