X-Git-Url: https://codewiz.org/gitweb?a=blobdiff_plain;f=bertos%2Frun_tests.sh;h=d42256485c1af3e7f999ec8cfe488a1d1778259d;hb=bb31ab5597a5a4299204f8c674f129506e0acdfe;hp=7edc89df78657e397a5860f8d38f96e4b7e302fe;hpb=791e167e053bdd9250d34a9a5ccae6ccde4d6679;p=bertos.git diff --git a/bertos/run_tests.sh b/bertos/run_tests.sh index 7edc89df..d4225648 100755 --- a/bertos/run_tests.sh +++ b/bertos/run_tests.sh @@ -1,36 +1,63 @@ #!/bin/bash # # Copyright 2005 Develer S.r.l. (http://www.develer.com/) -# All rights reserved. +# Copyright 2008 Bernie Innocenti # -# Author: Bernardo Innocenti +# Version: $Id$ +# Author: Bernie Innocenti # -# $Id$ -# - -VERBOSE=1 +# Testsuite output level: +# 0 - quiet +# 1 - progress output +# 2 - build warnings +# 3 - execution output +# 4 - build commands +VERBOSE=${VERBOSE:-1} CC=gcc -CFLAGS="-W -Wall -Wextra -I. -fno-builtin -D_DEBUG" +#FIXME: -Ibertos/emul should not be needed +CFLAGS="-W -Wall -Wextra -Ibertos -Ibertos/emul -std=gnu99 -fno-builtin -D_DEBUG -D'ARCH=(ARCH_EMUL|ARCH_UNITTEST)'" CXX=g++ CXXFLAGS="$CFLAGS" +TESTS=${TESTS:-`find . \ + \( -name .svn -prune -o -name .git -prune -o -name .hg -prune \) \ + -o -name "*_test.c*" -print` } + +TESTOUT="testout" + +buildout='/dev/null' +runout='/dev/null' +[ "$VERBOSE" -ge 2 ] && buildout='/dev/stdout' +[ "$VERBOSE" -ge 3 ] && runout='/dev/stdout' -for test in `find . -name "*_test.*"`; do - [ $VERBOSE -gt 0 ] && echo "Running $test..." - case "$test" in - *.cpp) - $CXX $CXXFLAGS $test -o test || exit 1 - ./test || exit 1 - rm -f test - ;; - *.c) - $CC $CFLAGS $test -o test || exit 1 - ./test || exit 1 - rm -f test - ;; +# Needed to get build/exec result code rather than tee's +set -o pipefail + +rm -rf "${TESTOUT}.old" +mv -f "${TESTOUT}" "$TESTOUT.old" +mkdir -p "$TESTOUT" + +for src in $TESTS; do + name="`basename $src | sed -e 's/\.cpp$//' -e 's/\.c$//'`" + exe="./$TESTOUT/$name" + + case "$src" in + *.cpp) BUILDCMD="$CXX $CXXFLAGS $src -o $exe" ;; + *.c) BUILDCMD="$CC $CXXFLAGS $src -o $exe" ;; esac + + [ $VERBOSE -gt 0 ] && echo "Building $name..." + [ $VERBOSE -gt 4 ] && echo " $BUILDCMD" + if $BUILDCMD 2>&1 | tee >$buildout $TESTOUT/$name.build; then + [ $VERBOSE -gt 0 ] && echo "Running $name..." + if ! $exe 2>&1 | tee >$runout $TESTOUT/$name.out; then + echo "FAILED [RUN]: $name" + fi + else + echo "FAILED [BUILD]: $name" + fi done