script to create a vserver with myplc-native for testing purposes
[build.git] / vtest-nightly.sh
1 #!/bin/bash
2 REVISION=$(echo '$Revision: 7654 $' | sed -e 's,\$,,g' -e 's,^\w*:\s,,' )
3
4 COMMANDPATH=$0
5 COMMAND=$(basename $0)
6
7 # default values, tunable with command-line options
8 DEFAULT_FCDISTRO=f7
9 DEFAULT_PLDISTRO=planetlab
10 DEFAULT_PERSONALITY=linux32
11 DEFAULT_BASE="@DATE@--test-@PLDISTRO@-@FCDISTRO@-@PERSONALITY@"
12 DEFAULT_SVNPATH="http://svn.planet-lab.org/svn/build/trunk"
13 DEFAULT_WEBPATH="/build/@PLDISTRO@/"
14
15 # for the test part
16 TESTSVNPATH="http://svn.planet-lab.org/svn/tests/trunk/system/"
17
18 ####################
19 # assuming vserver runs in UTC
20 DATE=$(date +'%Y.%m.%d')
21
22 # Notify recipient of failure or success, manage various stamps 
23 function failure() {
24     set -x
25     WEBLOG=${WEBPATH}/${BASE}.test-log.txt
26     cp $LOG ${WEBLOG}
27     (echo -n "============================== $COMMAND: failure at " ; date ; tail -c 20k $WEBLOG) > ${WEBLOG}.ko
28     if [ -n "$MAILTO" ] ; then
29         tail -c 20k ${WEBPATH}/${BASE}.log.txt | mail -s "Failures for test ${BASE}" $MAILTO
30     fi
31     exit 1
32 }
33
34 function success () {
35     set -x
36     WEBLOG=${WEBPATH}/${BASE}.test-log.txt
37     cp $LOG ${WEBLOG}
38     touch ${WEBLOG}.ok
39     if [ -n "$MAILTO" ] ; then
40         (echo "$PLDISTRO ($BASE) tests for $FCDISTRO completed on $(date)" ) | mail -s "Successful test for ${BASE}" $MAILTO
41     fi
42     exit 0
43 }
44
45 function show_env () {
46     set +x
47     echo FCDISTRO=$FCDISTRO
48     echo PLDISTRO=$PLDISTRO
49     echo BASE=$BASE
50     echo SVNPATH=$SVNPATH
51     echo MAKEVARS="${MAKEVARS[@]}"
52     echo MAKEOPTS="${MAKEOPTS[@]}"
53     echo PLDISTROTAGS="$PLDISTROTAGS"
54     echo TAGSRELEASE="$TAGSRELEASE"
55     echo -n "(might be unexpanded)"
56     echo WEBPATH="$WEBPATH"
57     if [ -d /vservers ] ; then
58         echo PLDISTROTAGS="$PLDISTROTAGS"
59     else
60         echo "XXXXXXXXXXXXXXXXXXXX Contents of tags definition file /build/$PLDISTROTAGS"
61         cat /build/$PLDISTROTAGS
62         echo "XXXXXXXXXXXXXXXXXXXX end tags definition"
63     fi
64     set -x
65 }
66
67 function usage () {
68     echo "Usage: $COMMAND [option] make-targets"
69     echo "This is $REVISION"
70     echo "Supported options"
71     echo " -n dry-run : -n passed to make - vserver gets created though - no mail sent"
72     echo " -f fcdistro - defaults to $DEFAULT_FCDISTRO"
73     echo " -d pldistro - defaults to $DEFAULT_PLDISTRO"
74     echo " -p personality - defaults to $DEFAULT_PERSONALITY"
75     echo " -b base - defaults to $DEFAULT_BASE"
76     echo "    @NAME@ replaced as appropriate"
77     echo " -t pldistrotags - defaults to \${PLDISTRO}-tags.mk"
78     echo " -r tagsrelease - a release number that refers to PLDISTROTAGS - defaults to HEAD"
79     echo " -s svnpath - where to fetch the build module"
80     echo " -o : overwrite - re-run in base directory, do not create vserver"
81     echo " -m mailto"
82     echo " -a makevar=value - space in values are not supported"
83     echo " -w webpath - defaults to $DEFAULT_WEBPATH"
84     echo " -v : be verbose"
85     echo " -7 : uses weekday-@FCDISTRO@ as base"
86     exit 1
87 }
88
89 function main () {
90
91     set -e
92
93     # preserve arguments for passing them again later
94     declare -a argv
95     for arg in "$@"; do argv=(${argv[@]} "$arg") ; done
96     
97     # parse arguments
98     MAKEVARS=()
99     MAKEOPTS=()
100     while getopts "nf:d:b:p:t:r:s:om:a:w:vh7" opt ; do
101         case $opt in
102             n) DRY_RUN="true" ; MAKEOPTS=(${MAKEOPTS[@]} -n) ;;
103             f) FCDISTRO=$OPTARG ;;
104             d) PLDISTRO=$OPTARG ;;
105             p) PERSONALITY=$OPTARG ;;
106             b) BASE=$OPTARG ;;
107             t) PLDISTROTAGS=$OPTARG ;;
108             r) TAGSRELEASE=$OPTARG ;;
109             s) SVNPATH=$OPTARG ;;
110             o) OVERWRITEMODE=true ;;
111             m) MAILTO=$OPTARG ;;
112             a) MAKEVARS=(${MAKEVARS[@]} "$OPTARG") ;;
113             w) WEBPATH=$OPTARG ;;
114             v) set -x ;;
115             7) BASE="$(date +%a|tr A-Z a-z)-@FCDISTRO@" ;;
116             h|*) usage ;;
117         esac
118     done
119         
120     shift $(($OPTIND - 1))
121     MAKETARGETS="$@"
122     
123     # set defaults
124     [ -z "$FCDISTRO" ] && FCDISTRO=$DEFAULT_FCDISTRO
125     [ -z "$PLDISTRO" ] && PLDISTRO=$DEFAULT_PLDISTRO
126     [ -z "$PERSONALITY" ] && PERSONALITY=$DEFAULT_PERSONALITY
127     [ -z "$PLDISTROTAGS" ] && PLDISTROTAGS="${PLDISTRO}-tags.mk"
128     [ -z "$BASE" ] && BASE="$DEFAULT_BASE"
129     [ -z "$WEBPATH" ] && WEBPATH="$DEFAULT_WEBPATH"
130     [ -z "$SVNPATH" ] && SVNPATH="$DEFAULT_SVNPATH"
131
132     [ -n "$DRY_RUN" ] && MAILTO=""
133         
134     ### set BASE from DISTRO, if unspecified
135     sedargs="-e s,@DATE@,${DATE},g -e s,@FCDISTRO@,${FCDISTRO},g -e s,@PLDISTRO@,${PLDISTRO},g -e s,@PERSONALITY@,${PERSONALITY},g"
136     BASE=$(echo ${BASE} | sed $sedargs)
137     WEBPATH=$(echo ${WEBPATH} | sed $sedargs)
138
139     trap failure ERR INT
140     # create vserver: check it does not exist yet
141     i=
142     while [ -d /vservers/${BASE}${i} ] ; do
143         # we name subsequent builds <base>-n<i> so the logs and builds get sorted properly
144         [ -z ${i} ] && BASE=${BASE}-n
145         i=$((${i}+1))
146         if [ $i -gt 100 ] ; then
147             echo "$COMMAND: Failed to create build vserver /vservers/${BASE}${i}"
148             exit 1
149         fi
150     done
151     BASE=${BASE}${i}
152     # need update
153     # manage LOG - beware it might be a symlink so nuke it first
154     LOG=/vservers/${BASE}.log.txt
155     rm -f $LOG
156     exec > $LOG 2>&1 
157     set -x
158     echo "XXXXXXXXXX $COMMAND: creating vserver $BASE" $(date)
159     show_env
160
161     ### extract the whole build - much simpler
162     tmpdir=/tmp/$COMMAND-$$
163     svn export $SVNPATH $tmpdir
164     # Create vserver
165     cd $tmpdir
166     REPOURL="http://build.planet-lab.org/install-rpms/archive/${PLDISTRO}/${FCDISTRO}/${DATE}--${PLDISTRO}-${FCDISTRO}-${PERSONALITY}/RPMS"
167     TESTVSERVERIP="10.201.197.1"
168     ./myplc-init-vserver.sh -f ${FCDISTRO} -d ${PLDISTRO} -p ${PERSONALITY} ${BASE} ${REPOURL} -- --interface eth0:${TESTVSERVERIP}
169     # cleanup
170     cd -
171     rm -rf $tmpdir
172
173     echo "XXXXXXXXXX $COMMAND: preparation of vserver $BASE done" $(date)
174     # The log inside the vserver contains everything
175     LOG2=/vservers/${BASE}/log.txt
176     (echo "==================== BEG VSERVER Transcript of vserver creation" ; \
177         cat $LOG ; \
178         echo "==================== END VSERVER Transcript of vserver creation" ; \
179         echo "xxxxxxxxxx Messing with logs, symlinking $LOG2 to $LOG" ) >> $LOG2
180     ### not too nice : nuke the former log, symlink it to the new one
181     rm $LOG; ln -s $LOG2 $LOG
182     LOG=$LOG2
183     # redirect log again
184     exec >> $LOG 2>&1 
185
186     # SVN download one or more tests and run them.  Call "failure" if
187     # the tests fail.
188     success 
189 }  
190
191 ##########
192 main "$@"