From 092a8a8aed195596f6e4c35e25a47c965e3526dc Mon Sep 17 00:00:00 2001 From: Gregory Nutt <gnutt@nuttx.org> Date: Tue, 30 Jun 2015 14:38:01 -0600 Subject: [PATCH] tools/testbuild.sh: Add a script that can be used perform test builds on a set of board configurations --- ChangeLog | 2 + tools/README.txt | 46 ++++++++- tools/testbuild.sh | 230 +++++++++++++++++++++++++++++++++++++++++++++ 3 files changed, 277 insertions(+), 1 deletion(-) create mode 100755 tools/testbuild.sh diff --git a/ChangeLog b/ChangeLog index 603f7f8b89..0d4a4a69b8 100755 --- a/ChangeLog +++ b/ChangeLog @@ -10639,4 +10639,6 @@ * arch/arm/src/armv6-m/up_assert.c: Port some per-process stack dumping logic from ARMv7-M to ARMv6-M. From Alan Carvalho de Assis (2015-06-30). + * tools/testbuild.sh: Add a script that can be used to perform + building testing for several board configurations (2015-06-30). diff --git a/tools/README.txt b/tools/README.txt index dd113624ed..ed000667e0 100644 --- a/tools/README.txt +++ b/tools/README.txt @@ -566,7 +566,51 @@ refresh.sh difference to the command line. refresh.sh will prompt you first to avoid overwriting the defconfig file with changes that you do not want. -` + + $ ./testbuild.sh -h + + USAGE: ./testbuild.sh [-w|l] [-c|n] <testlist-file> + USAGE: ./testbuild.sh -h + + where + -w|l selects Windows (w) or Linux (l). Default: Linux + -c|n selects Windows native (n) or Cygwin (c). Default Cygwin + -h will show this help test and terminate + <testlist-file> selects the list of configurations to test. No default + + Your PATH variable must include the path to both the build tools and the + kconfig-frontends tools + + These script needs essential two pieces of information. + + a. A description of the platform that you are testing on. This + description is provided by the optiona -w, -l, -c, and -n options. + b. A list of builds to perform. That list is provided by a test list + file. The final, non-optional parameter <testlist-file> provides + the path to that file. + + The test list file is a sequence of build descriptons, one per line. One + build descriptions consists of two comma separated values. For example: + + stm32f429i-disco/nsh,CONFIG_ARMV7M_TOOLCHAIN_GNU_EABIL + + The first value is the usual configuration description which of then + form <board-name>/<configuration-name> and must correspond to a + configuration in the nuttx/configs directory. + + The second value is valid name for a toolchain configuration to use + when building the configuration. The set of valid toolchain + configuration names depnds on the underlying architecture of the + configured board. + +testbuild.sh +------------ + + This script automates building of a sequence of configuration. The + intent is simply to assure that the set of configurations build + correctly. The -h option lists the usage: + + zipme.sh -------- diff --git a/tools/testbuild.sh b/tools/testbuild.sh new file mode 100755 index 0000000000..a94cb63b2f --- /dev/null +++ b/tools/testbuild.sh @@ -0,0 +1,230 @@ +#!/bin/bash +# version.sh +# +# Copyright (C) 2011 Gregory Nutt. All rights reserved. +# Author: Gregory Nutt <gnutt@nuttx.org> +# +# Redistribution and use in source and binary forms, with or without +# modification, are permitted provided that the following conditions +# are met: +# +# 1. Redistributions of source code must retain the above copyright +# notice, this list of conditions and the following disclaimer. +# 2. Redistributions in binary form must reproduce the above copyright +# notice, this list of conditions and the following disclaimer in +# the documentation and/or other materials provided with the +# distribution. +# 3. Neither the name NuttX nor the names of its contributors may be +# used to endorse or promote products derived from this software +# without specific prior written permission. +# +# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS +# FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE +# COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, +# INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, +# BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS +# OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED +# AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN +# ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +# POSSIBILITY OF SUCH DAMAGE. +# + +WD=$PWD +nuttx=$WD/../nuttx + +progname=$0 +host=l +wenv=c +unset testfile + +function showusage { + echo "" + echo "USAGE: $progname [-w|l] [-c|n] <testlist-file>" + echo "USAGE: $progname -h" + echo "" + echo "where" + echo " -w|l selects Windows (w) or Linux (l). Default: Linux" + echo " -c|n selects Windows native (n) or Cygwin (c). Default Cygwin" + echo " -h will show this help test and terminate" + echo " <testlist-file> selects the list of configurations to test. No default" + echo "" + echo "Your PATH variable must include the path to both the build tools and the" + echo "kconfig-frontends tools" + echo "" + exit 1 +} + +# Parse command line + +while [ ! -z "$1" ]; do + case $1 in + -w ) + host=w + ;; + -l ) + host=l + ;; + -c ) + wenv=c + ;; + -n ) + wenv=n + ;; + -h ) + showusage + ;; + * ) + testfile="$1" + shift + break; + ;; + esac + shift +done + +if [ ! -z "$1" ]; then + echo "ERROR: Garbage at the end of line" + showusage +fi + +if [ -z "$testfile" ]; then + echo "ERROR: Missing test list file" + showusage +fi + +if [ ! -r "$testfile" ]; then + echo "ERROR: No readable file exists at $testfile" + echo $USAGE + showusage +fi + +if [ ! -d "$nuttx" ]; then + echo "ERROR: Expected to find nuttx/ at $nuttx" + echo $USAGE + showusage +fi + +# Clean up after the last build + +function distclean { + cd $nuttx || { echo "ERROR: failed to CD to $nuttx"; exit 1; } + if [ -f .config ]; then + echo " Cleaning..." + make distclean 1>/dev/null + fi +} + +# Configure for the next build + +function configure { + cd $nuttx/tools || { echo "ERROR: failed to CD to $nuttx/tools"; exit 1; } + echo " Configuring..." + ./configure.sh $config + + cd $nuttx || { echo "ERROR: failed to CD to $nuttx"; exit 1; } + + if [ "X$host" == "Xl" ]; then + echo " Select CONFIG_HOST_LINUX=y" + + kconfig-tweak --file $nuttx/.config --enable CONFIG_HOST_LINUX + kconfig-tweak --file $nuttx/.config --disable CONFIG_HOST_WINDOWS + + kconfig-tweak --file $nuttx/.config --disable CONFIG_WINDOWS_NATIVE + kconfig-tweak --file $nuttx/.config --disable CONFIG_WINDOWS_CYGWIN + kconfig-tweak --file $nuttx/.config --disable CONFIG_WINDOWS_MSYS + kconfig-tweak --file $nuttx/.config --disable CONFIG_WINDOWS_OTHER + + else + echo " Select CONFIG_HOST_WINDOWS=y" + kconfig-tweak --file $nuttx/.config --enable CONFIG_HOST_WINDOWS + kconfig-tweak --file $nuttx/.config --disable CONFIG_HOST_LINUX + + if [ "X$wenv" == "Xc" ]; then + echo " Select CONFIG_HOST_CYGWIN=y" + kconfig-tweak --file $nuttx/.config --enable CONFIG_WINDOWS_CYGWIN + kconfig-tweak --file $nuttx/.config --disable CONFIG_WINDOWS_NATIVE + else + echo " Select CONFIG_HOST_MSYS=y" + kconfig-tweak --file $nuttx/.config --enable CONFIG_WINDOWS_NATIVE + kconfig-tweak --file $nuttx/.config --disable CONFIG_WINDOWS_CYGWIN + fi + + kconfig-tweak --file $nuttx/.config --disable CONFIG_WINDOWS_MSYS + kconfig-tweak --file $nuttx/.config --disable CONFIG_WINDOWS_OTHER + fi + + kconfig-tweak --file $nuttx/.config --disable CONFIG_HOST_OSX + kconfig-tweak --file $nuttx/.config --disable CONFIG_HOST_OTHER + + + setting=`grep TOOLCHAIN $nuttx/.config | grep =y` + varname=`echo $setting | cut -d'=' -f1` + if [ ! -z "varname" ]; then + echo " Disabling $varname" + kconfig-tweak --file $nuttx/.config --disable $varname + fi + + echo " Enabling $toolchain" + kconfig-tweak --file $nuttx/.config --enable $toolchain + + echo " Refreshing..." + kconfig-conf --olddefconfig Kconfig 1>/dev/null +} + +# Perform the next build + +function build { + cd $nuttx || { echo "ERROR: failed to CD to $nuttx"; exit 1; } + echo " Building..." + echo "------------------------------------------------------------------------------------" + make -i 1>/dev/null +} + +# Coordinate the steps for the next build test + +function dotest { + echo "------------------------------------------------------------------------------------" + distclean + configure + build +} + +# Performt he build test for each entry in the test list file + +export APPSDIR=../apps + +# Shouldn't have to do this + +testlist=`cat $testfile` + +#while read -r line || [[ -n $line ]]; do +for line in $testlist; do + echo "====================================================================================" + echo "Configuration/Tool Config: $line" + + # Parse the next line + + config=`echo $line | cut -d',' -f1` + + path=$nuttx/configs/$config + if [ ! -r "$path/defconfig" ]; then + echo "ERROR: no configuration fount at $path" + showusage + fi + + toolchain=`echo $line | cut -d',' -f2` + if [ -z "$toolchain" ]; then + echo "ERROR no tool configuration" + showusage + fi + + # Perform the build test + + dotest + cd $WD || { echo "ERROR: Failed to CD to $WD"; exit 1; } +done # < $testfile + +echo "===================================================================================="