diff options
author | Denys Vlasenko <vda.linux@googlemail.com> | 2017-07-06 17:59:25 +0200 |
---|---|---|
committer | Denys Vlasenko <vda.linux@googlemail.com> | 2017-07-06 17:59:25 +0200 |
commit | 9a8ece51582b83a2d4ed3e1854dca703d5113da2 (patch) | |
tree | ab95eba570a91d20796edbf935ad9bd755f92117 /shell/ash_test | |
parent | 3c9688e58737665d204ab70e6b0e10c745c99c30 (diff) |
shell: syncronize ash_test/run-all and hush_test/run-all a bit
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
Diffstat (limited to 'shell/ash_test')
-rwxr-xr-x | shell/ash_test/run-all | 102 |
1 files changed, 54 insertions, 48 deletions
diff --git a/shell/ash_test/run-all b/shell/ash_test/run-all index 8dfdddd9f..983e6d184 100755 --- a/shell/ash_test/run-all +++ b/shell/ash_test/run-all @@ -1,6 +1,6 @@ #!/bin/sh -TOPDIR=$PWD +TOPDIR=`pwd` test -x ash || { echo "No ./ash - creating a link to ../../busybox" @@ -10,67 +10,73 @@ test -x printenv || gcc -O2 -o printenv printenv.c || exit $? test -x recho || gcc -O2 -o recho recho.c || exit $? test -x zecho || gcc -O2 -o zecho zecho.c || exit $? -PATH="$PWD:$PATH" # for ash and recho/zecho/printenv +PATH="`pwd`:$PATH" # for ash and recho/zecho/printenv export PATH -THIS_SH="$PWD/ash" +THIS_SH="`pwd`/ash" export THIS_SH do_test() { - test -d "$1" || return 0 -# echo do_test "$1" - # $1 but with / replaced by # so that it can be used as filename part - noslash=`echo "$1" | sed 's:/:#:g'` - ( - cd "$1" || { echo "cannot cd $1!"; exit 1; } - for x in run-*; do - test -f "$x" || continue - case "$x" in - "$0"|run-minimal|run-gprof) ;; - *.orig|*~) ;; - #*) echo $x ; sh $x ;; - *) - echo -n "$1/$x: " - sh "$x" >"$TOPDIR/$noslash-$x.fail" 2>&1 && \ - { echo "ok"; rm "$TOPDIR/$noslash-$x.fail"; } || echo "fail"; - ;; - esac - done - # Many bash run-XXX scripts just do this, - # no point in duplication it all over the place - for x in *.tests; do - test -x "$x" || continue - name="${x%%.tests}" - test -f "$name.right" || continue - echo -n "$1/$x: " - { - "$THIS_SH" "./$x" >"$name.xx" 2>&1 - diff -u "$name.xx" "$name.right" >"$TOPDIR/$noslash-$x.fail" \ - && rm -f "$name.xx" "$TOPDIR/$noslash-$x.fail" - } && echo "ok" || echo "fail" - done - ) + test -d "$1" || return 0 + d=${d%/} +# echo Running tests in directory "$1" + # $1 but with / replaced by # so that it can be used as filename part + noslash=`echo "$1" | sed 's:/:#:g'` + ( + cd "$1" || { echo "cannot cd $1!"; exit 1; } + for x in run-*; do + test -f "$x" || continue + case "$x" in + "$0"|run-minimal|run-gprof) ;; + *.orig|*~) ;; + #*) echo $x ; sh $x ;; + *) + echo -n "$1/$x:" + sh "$x" >"$TOPDIR/$noslash-$x.fail" 2>&1 && \ + { { echo " ok"; rm "$TOPDIR/$noslash-$x.fail"; } || echo " fail"; } + ;; + esac + done + # Many bash run-XXX scripts just do this, + # no point in duplication it all over the place + for x in *.tests; do + test -x "$x" || continue + name="${x%%.tests}" + test -f "$name.right" || continue +# echo Running test: "$x" + echo -n "$1/$x:" + { + "$THIS_SH" "./$x" >"$name.xx" 2>&1 + diff -u "$name.xx" "$name.right" >"$TOPDIR/$noslash-$x.fail" \ + && rm -f "$name.xx" "$TOPDIR/$noslash-$x.fail" + } && echo " ok" || echo " fail" + done + ) } -# main part of this script +# Main part of this script # Usage: run-all [directories] +ret=0 + if [ $# -lt 1 ]; then - # All sub directories - modules=`ls -d ash-*` - # If you want to test ash against hush testsuite - # (have to copy hush_test dir to current dir first): - #modules=`ls -d ash-* hush_test/hush-*` + # All sub directories + modules=`ls -d ash-*` + # If you want to test ash against hush testsuite + # (have to copy hush_test dir to current dir first): + #modules=`ls -d ash-* hush_test/hush-*` - for module in $modules; do - do_test $module - done + for module in $modules; do + do_test $module || ret=1 + done else - while [ $# -ge 1 ]; do + while [ $# -ge 1 ]; do if [ -d $1 ]; then - do_test $1 + do_test $1 || ret=1 fi shift - done + done fi + +exit ${ret} |