diff options
-rwxr-xr-x | util/abuild/abuild | 155 | ||||
-rw-r--r-- | util/abuild/abuild.1 | 9 |
2 files changed, 113 insertions, 51 deletions
diff --git a/util/abuild/abuild b/util/abuild/abuild index 53b492bfe0..61ea37abe1 100755 --- a/util/abuild/abuild +++ b/util/abuild/abuild @@ -14,6 +14,9 @@ #set -x # Turn echo on.... +ABUILD_DATE="October 24, 2006" +ABUILD_VERSION="0.4" + # Where shall we place all the build trees? TARGET=$( pwd )/linuxbios-builds XMLFILE=$( pwd )/abuild.xml @@ -24,6 +27,8 @@ PAYLOAD=/dev/null # Lines of error context to be printed in FAILURE case CONTEXT=5 +TESTSUBMISSION="http://qa.linuxbios.org/deployment/send.php" + # One might want to adjust these in case of cross compiling MAKE="make" PYTHON=python @@ -35,19 +40,34 @@ ARCH=`uname -m | sed -e s/i.86/i386/ -e s/sun4u/sparc64/ \ -e s/arm.*/arm/ -e s/sa110/arm/ -e s/x86_64/amd64/ \ -e "s/Power Macintosh/ppc/"` +trap interrupt INT + +function interrupt +{ + printf "\n$0: execution interrupted manually.\n" + if [ "$mode" == "xml" ]; then + printf "$0: deleting incomplete xml output file.\n" + fi + exit 1 +} + function debug { - test "$verbose" == "true" && echo $* + test "$verbose" == "true" && printf "$*\n" } function xml { - test "$mode" == "xml" && echo "$*" >> $XMLFILE + test "$mode" == "xml" && printf "$*\n" >> $XMLFILE } function xmlfile { - test "$mode" == "xml" && { echo '<![CDATA['; cat $1; echo ']]>'; } >> $XMLFILE + test "$mode" == "xml" && { + printf '<![CDATA[\n' + cat $1 + printf ']]>\n' + } >> $XMLFILE } @@ -88,18 +108,18 @@ function create_config if [ -x $payloads/payload.sh ]; then PAYLOAD=`$payloads/payload.sh $VENDOR $MAINBOARD` - echo "Using custom payload $PAYLOAD" + printf "Using custom payload $PAYLOAD\n" fi mkdir -p $TARGET if [ -f $TARGCONFIG ]; then cp $TARGCONFIG $TARGET/Config-${VENDOR}_${MAINBOARD}.lb - echo -n "Using existing test target $TARGCONFIG" + printf "Using existing test target $TARGCONFIG" xml " <config>$TARGCONFIG</config>" else - echo -n " Creating config file..." + printf " Creating config file..." xml " <config>autogenerated</config>" ( cat << EOF # This will make a target directory of ./VENDOR_MAINBOARD @@ -149,7 +169,7 @@ EOF -e s,CROSS_HOSTCC,"$HOSTCC",g \ $TARGET/Config-${VENDOR}_${MAINBOARD}.lb - echo " ok" + printf " ok\n" } function create_builddir @@ -157,7 +177,7 @@ function create_builddir VENDOR=$1 MAINBOARD=$2 - echo -n " Creating builddir..." + printf " Creating builddir..." target_dir=$TARGET config_dir=$LBROOT/util/newconfig @@ -182,12 +202,12 @@ function create_builddir export PYTHONPATH=$config_dir $PYTHON $config_py $config_lb $LBROOT &> $build_dir/config.log if [ $? -eq 0 ]; then - echo "ok" + printf "ok\n" xml " <builddir>ok</builddir>" xml "" return 0 else - echo "FAILED! Log excerpt:" + printf "FAILED! Log excerpt:\n" xml " <builddir>failed</builddir>" xml " <log>" xmlfile $build_dir/config.log @@ -211,7 +231,7 @@ function compile_target VENDOR=$1 MAINBOARD=$2 - echo -n " Compiling image .." + printf " Compiling image .." CURR=$( pwd ) cd $TARGET/${VENDOR}_${MAINBOARD} stime=`date +%s` @@ -222,8 +242,8 @@ function compile_target if [ $ret -eq 0 ]; then xml " <compile>ok</compile>" xml " <compiletime>${duration}s</compiletime>" - echo "ok" > compile.status - echo "ok. (took ${duration}s)" + printf "ok\n" > compile.status + printf "ok. (took ${duration}s)\n" cd $CURR return 0 else @@ -233,7 +253,7 @@ function compile_target xmlfile make.log xml " </log>" - echo "FAILED after ${duration}s! Log excerpt:" + printf "FAILED after ${duration}s! Log excerpt:\n" tail -n $CONTEXT make.log cd $CURR return 1 @@ -273,7 +293,7 @@ function build_target HOSTCC='gcc' CROSS_COMPILE='' - echo -n "Processing mainboard/$VENDOR/$MAINBOARD" + printf "Processing mainboard/$VENDOR/$MAINBOARD" xml "<mainboard>" xml "" @@ -287,7 +307,7 @@ function build_target source $LBROOT/src/mainboard/${VENDOR}/${MAINBOARD}/abuild.info if [ "$ARCH" == "$TARCH" ]; then - echo " ($TARCH: ok)" + printf " ($TARCH: ok)\n" else found_crosscompiler=false if [ "$ARCH" == amd64 -a "$TARCH" == i386 ]; then @@ -314,15 +334,14 @@ function build_target # Check result: if [ $found_crosscompiler == "false" ]; then - echo " ($TARCH: skipped, we're $ARCH)" - echo + printf " ($TARCH: skipped, we're $ARCH)\n\n" xml " <status>notbuilt</status>" xml "" xml "</mainboard>" return 0 else - echo " ($TARCH: ok, we're $ARCH)" + printf " ($TARCH: ok, we're $ARCH)\n" xml " <compiler>" xml " <path>`which ${CROSS_COMPILE}gcc`</path>" xml " <version>`${CROSS_COMPILE}gcc --version | head -1`</version>" @@ -333,8 +352,7 @@ function build_target built_successfully $VENDOR $MAINBOARD && \ { - echo " ( mainboard/$VENDOR/$MAINBOARD previously ok )" - echo + printf " ( mainboard/$VENDOR/$MAINBOARD previously ok )\n\n" xml " <status>previouslyok</status>" xml "" xml "</mainboard>" @@ -343,8 +361,7 @@ function build_target build_broken $VENDOR $MAINBOARD || \ { - echo " ( broken mainboard/$VENDOR/$MAINBOARD skipped )" - echo + printf " ( broken mainboard/$VENDOR/$MAINBOARD skipped )\n\n" xml " <status>knownbroken</status>" xml "" xml "</mainboard>" @@ -354,51 +371,88 @@ function build_target create_buildenv $VENDOR $MAINBOARD if [ $? -eq 0 ]; then compile_target $VENDOR $MAINBOARD && - xml "<status>ok</status>" || + xml " <status>ok</status>" || xml "<status>broken</status>" fi xml "" xml "</mainboard>" - echo + printf "\n" +} + +function test_target +{ + VENDOR=$1 + MAINBOARD=$2 + + if [ "$hwtest" != "true" ]; then + return 0 + fi + + # image does not exist. we silently skip the patch. + if [ ! -r "$TARGET/${VENDOR}_${MAINBOARD}/linuxbios.rom" ]; then + return 0 + fi + + which curl &> /dev/null + if [ $? != 0 ]; then + printf "curl is not installed but required for test submission. skipping test.\n\n" + return 0 + fi + + CURR=`pwd` + if [ -r "$TARGET/${VENDOR}_${MAINBOARD}/tested" ]; then + printf "Testing image for board $VENDOR $MAINBOARD skipped (previously submitted).\n\n" + return 0 + fi + # touch $TARGET/${VENDOR}_${MAINBOARD}/tested + + printf "Submitting image for board $VENDOR $MAINBOARD to test system...\n" + + curl -f -F "romfile=@$TARGET/${VENDOR}_${MAINBOARD}/linuxbios.rom" \ + -F "mode=abuild" -F "mainboard=${VENDOR}_${MAINBOARD}" -F "submit=Upload" \ + "http://qa.linuxbios.org/deployment/send.php" + + printf "\n" + return 0 } function myhelp { - echo "Usage: $0 [-v] [-a] [-b] [-t <vendor/board>] [-p <dir>] [lbroot]" - echo " $0 [-V|--version]" - echo " $0 [-h|--help]" - echo - echo "Options:" - echo " [-v|--verbose] print more messages" - echo " [-a|--all] build previously succeeded ports as well" - echo " [-b|--broken] attempt to build ports that are known broken" - echo " [-t|--target <vendor/board>] attempt to build target vendor/board only" - echo " [-p|--payloads <dir>] use payloads in <dir> to build images" - echo " [-V|--version] print version number and exit" - echo " [-h|--help] print this help and exit" - echo " [-x|--xml] write xml log file " - echo " (defaults to $XMLFILE)" - echo " [lbroot] absolute path to LinuxBIOS sources" - echo " (defaults to $LBROOT)" - echo + printf "Usage: $0 [-v] [-a] [-b] [-t <vendor/board>] [-p <dir>] [lbroot]\n" + printf " $0 [-V|--version]\n" + printf " $0 [-h|--help]\n" + printf + printf "Options:\n" + printf " [-v|--verbose] print more messages\n" + printf " [-a|--all] build previously succeeded ports as well\n" + printf " [-b|--broken] attempt to build ports that are known broken\n" + printf " [-t|--target <vendor/board>] attempt to build target vendor/board only\n" + printf " [-p|--payloads <dir>] use payloads in <dir> to build images\n" + printf " [-V|--version] print version number and exit\n" + printf " [-h|--help] print this help and exit\n" + printf " [-x|--xml] write xml log file \n" + printf " (defaults to $XMLFILE)\n" + printf " [-T|--test] submit image(s) to automated test system\n" + printf " [lbroot] absolute path to LinuxBIOS sources\n" + printf " (defaults to $LBROOT)\n\n" } function myversion { cat << EOF -LinuxBIOS autobuild: V0.3. +LinuxBIOS autobuild v$ABUILD_VERSION ($ABUILD_DATE) Copyright (C) 2004 by Stefan Reinauer <stepan@openbios.org> Copyright (C) 2006 by coresystems GmbH <info@coresystems.de> + This program is free software; you may redistribute it under the terms of the GNU General Public License. This program has absolutely no warranty. EOF - myhelp } # default options @@ -408,7 +462,7 @@ LBROOT=$( cd ../..; pwd ) verbose=false # parse parameters -args=`getopt -l version,verbose,help,all,target:,broken,payloads: Vvhat:bp: -- "$@"` +args=`getopt -l version,verbose,help,all,target:,broken,payloads:,test Vvhat:bp:T -- "$@"` if [ $? != 0 ]; then myhelp @@ -424,10 +478,11 @@ while true ; do -b|--broken) shift; buildbroken=true;; -v|--verbose) shift; verbose=true;; -V|--version) shift; myversion; exit 0;; - -h|--help) shift; myhelp; exit 0;; + -h|--help) shift; myversion; myhelp; exit 0;; -p|--payloads) shift; payloads="$1"; shift;; + -T|--test) shift; hwtest=true;; --) shift; break;; - -*) echo -e "Invalid option\n"; myhelp; exit 1;; + -*) printf "Invalid option\n\n"; myhelp; exit 1;; *) break;; esac done @@ -442,14 +497,16 @@ xml '<abuild>' if [ "$target" != "" ]; then # build a single board - VENDOR=`echo $target|cut -f1 -d/` - MAINBOARD=`echo $target|cut -f2 -d/` + VENDOR=`printf $target|cut -f1 -d/` + MAINBOARD=`printf $target|cut -f2 -d/` build_target $VENDOR $MAINBOARD + test_target $VENDOR $MAINBOARD else # build all boards per default for VENDOR in $( vendors ); do for MAINBOARD in $( mainboards $VENDOR ); do build_target $VENDOR $MAINBOARD + test_target $VENDOR $MAINBOARD done done fi diff --git a/util/abuild/abuild.1 b/util/abuild/abuild.1 index e808978322..efab83d46d 100644 --- a/util/abuild/abuild.1 +++ b/util/abuild/abuild.1 @@ -1,4 +1,4 @@ -.TH ABUILD 1 "September 19, 2006" +.TH ABUILD 1 "October 24, 2006" .SH NAME abuild \- build LinuxBIOS images for all available targets .SH SYNOPSIS @@ -41,6 +41,11 @@ The file will be called .B abuild.xml and will be created in the current directory. .TP +.B "\-T, \-\-test" +Submit generated image(s) to the automated test system. +The results of the tests will be made available at +.B http://qa.linuxbios.org/log_manual.php +.TP .B "\-v, \-\-verbose" More verbose output. .TP @@ -62,7 +67,7 @@ is covered by the GNU General Public License (GPL), version 2 or later. .br 2006 coresystems GmbH .SH AUTHORS -Stefan Reinauer <stepan@openbios.org> +Stefan Reinauer <stepan@coresystems.de> .PP This manual page was written by Uwe Hermann <uwe@hermann-uwe.de>. It is licensed under the terms of the GNU GPL (v2 or later). |