@@ -5,15 +5,16 @@ TOOLCHAINS_URL='http://autobuild.buildroot.org/toolchains/configs/toolchain-conf
main() {
local o O opts
- local cfg dir pkg toolchain
+ local cfg dir pkg random toolchain
local ret nb_dl nb_cfg nb_skip nb_clean nb_build
local -a toolchains
- o='hc:d:p:'
- O='help,config-snippet:build-dir:package:'
+ o='hc:d:p:r:'
+ O='help,config-snippet:build-dir:package:,random:'
opts="$( getopt -n "${my_name}" -o "${o}" -l "${O}" -- "${@}" )"
eval set -- "${opts}"
+ random=0
while [ ${#} -gt 0 ]; do
case "${1}" in
(-h|--help)
@@ -28,6 +29,9 @@ main() {
(-p|--package)
pkg="${2}"; shift 2
;;
+ (-r|--random)
+ random="${2}"; shift 2
+ ;;
(--)
shift; break
;;
@@ -44,7 +48,12 @@ main() {
# E.g.: http://server/path/to/name.config,arch,libc
# --> http://server/path/to/name.config
toolchains=( $( curl -s "${TOOLCHAINS_URL}" \
- |sed -r -e 's/,.*//; /internal/d;'
+ |sed -r -e 's/,.*//; /internal/d;' \
+ |if [ ${random} -gt 0 ]; then \
+ sort -R |head -n ${random}
+ else
+ cat
+ fi |sort
)
)
@@ -189,6 +198,10 @@ Options:
Test-build the package PKG, by running 'make PKG'; if not specified,
just runs 'make'.
+ -r N, --random N
+ Limit the tests to the N randomly selected toolchains, instead of
+ building with all toolchains.
+
Example:
Testing libcec would require a config snippet that contains:
Sometimes, it interesting to have a global overview of whether the package builds at all or not, rather than test on all toolchains. Add an option that allows testing on a limited set of randomly choosen toolchains. Signed-off-by: "Yann E. MORIN" <yann.morin.1998@free.fr> Cc: Thomas Petazzoni <thomas.petazzoni@free-electrons.com> Cc: Luca Ceresoli <luca@lucaceresoli.net> Cc: Thomas De Schampheleire <patrickdepinguin@gmail.com> --- Changes v1 -> v2; - fix when option is not provided --- support/scripts/test-pkg | 21 +++++++++++++++++---- 1 file changed, 17 insertions(+), 4 deletions(-)