abuild: Write XML/JUnit files per board

Write them per-board and merge them after everything is done.
This prepares for build parallelization.

Change-Id: Ia4e7ce03473bcf8861fb9ae06e9c1270292401ac
Signed-off-by: Patrick Georgi <patrick@georgi-clan.de>
Reviewed-on: http://review.coreboot.org/407
Tested-by: build bot (Jenkins)
Reviewed-by: Stefan Reinauer <stefan.reinauer@coreboot.org>
This commit is contained in:
Patrick Georgi 2011-11-05 13:21:14 +01:00 committed by Stefan Reinauer
parent f49f7c8514
commit 3db85f3c1b

View file

@ -17,9 +17,12 @@
ABUILD_DATE="December 10th, 2010" ABUILD_DATE="December 10th, 2010"
ABUILD_VERSION="0.9.1" ABUILD_VERSION="0.9.1"
TOP=$PWD
# Where shall we place all the build trees? # Where shall we place all the build trees?
TARGET=coreboot-builds TARGET=coreboot-builds
XMLFILE=$( pwd )/abuild.xml XMLFILE=$TOP/abuild.xml
REAL_XMLFILE=$XMLFILE
# path to payload. Should be more generic # path to payload. Should be more generic
PAYLOAD=/dev/null PAYLOAD=/dev/null
@ -363,6 +366,7 @@ function build_target
HOSTCC='gcc' HOSTCC='gcc'
printf "Building $VENDOR/$MAINBOARD; " printf "Building $VENDOR/$MAINBOARD; "
XMLFILE=$TOP/$TARGET/${VENDOR}_${MAINBOARD}/abuild.xml
xml "<mainboard>" xml "<mainboard>"
xml "" xml ""
@ -652,6 +656,8 @@ if [ "$target" != "" ]; then
fi fi
build_target $VENDOR $MAINBOARD $CONFIG build_target $VENDOR $MAINBOARD $CONFIG
test_target $VENDOR $MAINBOARD test_target $VENDOR $MAINBOARD
cat $TARGET/${VENDOR}_${MAINBOARD}/abuild.xml >> $REAL_XMLFILE
XMLFILE=$REAL_XMLFILE
else else
# build all boards per default # build all boards per default
for VENDOR in $( vendors ); do for VENDOR in $( vendors ); do
@ -661,6 +667,10 @@ else
remove_target $VENDOR $MAINBOARD remove_target $VENDOR $MAINBOARD
done done
done done
for xmlfile in $TARGET/*_*/abuild.xml; do
cat $xmlfile >> $REAL_XMLFILE
done
XMLFILE=$REAL_XMLFILE
fi fi
xml '</abuild>' xml '</abuild>'
junit '</testsuite>' junit '</testsuite>'