summaryrefslogtreecommitdiffhomepage
path: root/shell/ash_test
diff options
context:
space:
mode:
authorDenys Vlasenko <vda.linux@googlemail.com>2017-07-06 17:59:25 +0200
committerDenys Vlasenko <vda.linux@googlemail.com>2017-07-06 17:59:25 +0200
commit9a8ece51582b83a2d4ed3e1854dca703d5113da2 (patch)
treeab95eba570a91d20796edbf935ad9bd755f92117 /shell/ash_test
parent3c9688e58737665d204ab70e6b0e10c745c99c30 (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-xshell/ash_test/run-all102
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}