support submitting tests to the test system in abuild. initial support.
Signed-off-by: Stefan Reinauer <stepan@coresystems.de> Closes #3 git-svn-id: svn://svn.coreboot.org/coreboot/trunk@2474 2b7e53f0-3cfb-0310-b3e9-8179ed1497e1
This commit is contained in:
parent
3d61074108
commit
3a1405725e
2 changed files with 113 additions and 51 deletions
|
@ -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
|
||||
|
|
|
@ -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).
|
||||
|
|
Loading…
Reference in a new issue