2 REVISION=$(echo '$Revision$' | sed -e 's,\$,,g' -e 's,^\w*:\s,,' )
8 # default values, tunable with command-line options
10 SVNPATH="http://svn.one-lab.org/build/trunk"
12 MAILTO="onelab-build@one-lab.org"
13 DISTROMAKETAGS=onelab-tags.mk
14 PLEBOX=root@planet-lab.eu
15 TESTBUILDURL="http://build.one-lab.org/"
16 TESTBOX=onelab-test.inria.fr
17 TESTBOXSSH=root@onelab-test.inria.fr
18 TESTSVNPATH="http://svn.one-lab.org/new_plc_api/trunk/plctest"
19 TESTSCRIPT=TestMain.py
22 # plc chroot runs in UTC
23 DATE=$(date -u +'%Y.%m.%d')
25 # Notify recipient of failure or success, manage various stamps
28 (echo -n "============================== $COMMAND: failure at" ; date ; tail -c 20k /log-build.txt) >> /build.broken
29 if [ -n "$MAILTO" ] ; then
30 tail -c 8k /log-build.txt | mail -s "Failures for ${BASE}" $MAILTO
38 if [ -n "$MAILTO" ] ; then
39 (echo "http://build.one-lab.org/$DISTRO/$BASE" ; echo "Completed on $(date)" ) | mail -s "Successfull build for ${BASE}" $MAILTO
52 echo -n "============================== Starting $COMMAND:build on "
56 # svn checkout $SVNPATH $BASE
58 # if TAGSRELEASE specified : update DISTROMAKETAGS with this tag
59 if [ -n "$TAGSRELEASE" ] ; then
61 svn up -r $TAGSRELEASE $DISTROMAKETAGS
67 echo "Running make IN $(pwd)"
68 make stage1=true "${MAKEOPTS[@]}" DISTROMAKETAGS=${DISTROMAKETAGS} PLDISTRO=${DISTRO} "${MAKEVARS[@]}" -C /build
69 # in case we use an older build
71 make "${MAKEOPTS[@]}" DISTROMAKETAGS=${DISTROMAKETAGS} PLDISTRO=${DISTRO} "${MAKEVARS[@]}" -C /build versions
73 make "${MAKEOPTS[@]}" DISTROMAKETAGS=${DISTROMAKETAGS} PLDISTRO=${DISTRO} "${MAKEVARS[@]}" -C /build $MAKETARGETS
75 # restore silent mode - otherwise cron gets it
84 echo -n"==============================> testing the sendmail service on PLE"
85 ssh ${PLEBOX} python -u /root/${TESTSEND}
87 echo -n "============================== Starting $COMMAND:runtest on "
91 ### compute URL to the myplc package
93 buildname=$(basename $build)
95 rpm=$(find RPMS -name myplc\*.rpm )
96 url=${TESTBUILDURL}${DISTRO}/${buildname}/${rpm}
97 ### checkout the test material
98 svn co ${TESTSVNPATH} plctest
99 # compute test directory name on test box
100 testdir=plctest-${buildname}
101 # rsync/push test material onto the test box
102 ssh ${TESTBOXSSH} mkdir -p ${testdir}
103 rsync -a -v plctest/ ${TESTBOXSSH}:${testdir}
104 # invoke test on testbox
105 ssh ${TESTBOXSSH} python -u ${testdir}/${TESTSCRIPT} ${url}
106 #invoke make install from build to the testbox
107 make install PLCHOST=${TESTBOX}
109 if [ "$?" != 0 ] ; then
116 function show_env () {
118 echo FC_DISTRO=$FC_DISTRO
121 echo SVNPATH=$SVNPATH
122 echo MAKEVARS="${MAKEVARS[@]}"
123 echo MAKEOPTS="${MAKEOPTS[@]}"
124 echo DISTROMAKETAGS="$DISTROMAKETAGS"
125 echo TAGSRELEASE="$TAGSRELEASE"
126 if [ -f /build/$DISTROMAKETAGS ] ; then
127 echo "XXXXXXXXXXXXXXXXXXXX Contents of tags definition file $DISTROMAKETAGS"
128 cat /build/$DISTROMAKETAGS
130 echo "no tags definition yet - probably out of vserver"
132 echo "XXXXXXXXXXXXXXXXXXXX end tags definition"
136 echo "Usage: $COMMAND [option] make-targets"
137 echo "This is revision $REVISION"
138 echo "Supported options"
139 echo " -n dry-run : -n passed to make - no mail sent"
141 echo " -b BASE - may include @, then replaced with current date"
142 echo " -t PLDISTROMAKETAGS"
143 echo " -r TAGSRELEASE - a release number that refers to PLDISTROMAKETAGS - defaults to HEAD"
144 echo " -s SVNPATH - where to fetch the build module"
145 echo " -f FC_DISTRO - defaults to $DEFAULT_FC_DISTRO"
146 echo " -u : uses directory given as BASE as is, even if already exists"
147 echo " -s MAKEVAR=value"
149 echo " -B : run build only"
150 echo " -T : run test only"
158 # preserve arguments for passing them again later
160 for arg in "$@"; do argv=(${argv[@]} "$arg") ; done
162 for x in "${argv[@]}"; do echo 'argv>'$x'<' ; done
169 while getopts "f:b:ud:t:r:s:nm:s:BTh" opt ; do
171 f) FC_DISTRO=$OPTARG ;;
175 t) DISTROMAKETAGS=$OPTARG ;;
176 r) TAGSRELEASE=$OPTARG ;;
177 s) MAKEVARS=(${MAKEVARS[@]} "$OPTARG") ;;
178 n) MAILTO="" ; MAKEOPTS=(${MAKEOPTS[@]} -n) ;;
180 s) SVNPATH=$OPTARG ;;
182 T) DO_BUILD= ; USEOLD=true ;;
187 shift $(($OPTIND - 1))
189 [ -z "$FC_DISTRO" ] && FC_DISTRO=$DEFAULT_FC_DISTRO
192 ### set BASE from DISTRO, if unspecified
193 [ -z "$BASE" ] && BASE=${DISTRO}-${FC_DISTRO}
194 BASE=$(echo ${BASE} | sed -e "s,@,${DATE},g")
196 if [ -d /vservers ] ; then
197 # we run in the root context :
198 # (*) create or check for the vserver to use
199 # (*) copy this command in the vserver
202 if [ -n "$USEOLD" ] ; then
203 ### Re-use a vserver (finish an unfinished build..)
204 if [ ! -d /vservers/${BASE} ] ; then
205 echo $COMMAND : cannot find vserver $BASE
209 LOG=/vservers/${BASE}.log
210 echo "XXXXXXXXXX $COMMAND: using existing vserver $BASE" $(date) >> $LOG 2>&1
211 vserver ${BASE} exec svn update /build >> $LOG 2>&1
213 # create vserver: check it does not exist yet
215 while [ -d /vservers/${BASE}${i} ] ; do
216 # we name subsequent builds <base>-n<i> so the logs and builds get sorted properly
217 [ -z ${i} ] && BASE=${BASE}-n
219 if [ $i -gt 100 ] ; then
220 echo "$COMMAND: Failed to create build vserver /vservers/${BASE}${i}"
225 LOG=/vservers/${BASE}.log
226 echo "XXXXXXXXXX $COMMAND: creating vserver $BASE" $(date) >> $LOG 2>&1
227 show_env >> $LOG 2>&1
228 ### extract vbuild.setup and run it
229 svn cat $SVNPATH/vbuild.setup > /tmp/vbuild-$$ 2>> $LOG
230 svn cat $SVNPATH/${DISTRO}-devel.lst > /tmp/${DISTRO}-devel.lst 2>> $LOG
234 /tmp/vbuild-$$ ${BASE} ${FC_DISTRO} ${DISTRO} >> $LOG 2>&1
237 vserver ${BASE} exec svn checkout ${SVNPATH} /build >> $LOG 2>&1
240 echo "XXXXXXXXXX $COMMAND: preparation of vserver $BASE done" $(date) >> $LOG 2>&1
241 cp $COMMANDPATH /vservers/${BASE}/
242 # invoke this command in the vserver
243 vserver ${BASE} exec /$COMMAND "${argv[@]}" >> $LOG 2>&1
246 if [ -n "$DO_BUILD" ] ; then
251 # xxx - need to gather builds under the build index before we can re-enable this
252 #if [ -n "$DO_TEST" ] ; then
260 # todo : gather results from various vservers into a single build index