don't out \r to syslog
[oweals/busybox.git] / testsuite / runtest
index b19be3dd8cdd2a69b19a9500662e96ccf7e52f55..4ac1d3bfed0b637ab5fe61383c26e2145446dc8c 100755 (executable)
@@ -1,6 +1,8 @@
 #!/bin/sh
 
-PATH=$(dirname $(pwd)):$PATH
+[ -n "$srcdir" ] || srcdir=$(pwd)
+[ -n "$bindir" ] || bindir=$(dirname $(pwd))
+PATH=$bindir:$PATH
 
 run_applet_testcase ()
 {
@@ -8,44 +10,42 @@ run_applet_testcase ()
        local testcase=$2
 
        local status=0
-       local U=
-       local X=
+       local RES=
 
        local uc_applet=$(echo $applet | tr a-z A-Z)
        local testname=$(basename $testcase)
 
-       if grep -q "^# CONFIG_${uc_applet} is not set$" ../.config; then
-               echo "UNSUPPORTED: $testname"
+       if grep -q "^# CONFIG_${uc_applet} is not set$" $bindir/.config; then
+               echo UNTESTED: $testname
                return 0
        fi
 
-       if grep -q "^# UNSUPPORTED: " $testcase; then
-               local feature=`sed -ne 's/.*UNSUPPORTED: //p' $testcase`
+       if grep -q "^# FEATURE: " $testcase; then
+               local feature=`sed -ne 's/^# FEATURE: //p' $testcase`
 
-               if grep -q "^# ${feature} is not set$" ../.config; then
-                       echo "UNSUPPORTED: $testname"
+               if grep -q "^# ${feature} is not set$" $bindir/.config; then
+                       echo UNTESTED: $testname
                        return 0
                fi
        fi
 
-       if grep -q "^# XFAIL$" $testcase; then
-               U=U
-               X=X
-       fi
-
-       mkdir tmp
+       rm -rf tmp
+       mkdir -p tmp
        pushd tmp >/dev/null
 
-       if . ../$testcase >/dev/null 2>&1; then
-               echo "${U}PASS: $testname"
-               if [ "$U" ]; then
-                       status=1
-               fi
+       d=$srcdir sh -x -e $testcase >.logfile.txt 2>&1
+
+       if [ $? != 0 ] ; then
+               echo FAIL: $testname
+               if [ "$verbose" = 1 ]; then
+                       cat .logfile.txt
+                       #exit 1;
+               fi;
+               status=$?
        else
-               echo "${X}FAIL: $testname"
-               if [ ! "$X" ]; then
-                       status=1
-               fi
+               echo PASS: $testname
+               rm -f .logfile.txt
+               status=$?
        fi
 
        popd >/dev/null
@@ -60,8 +60,8 @@ run_applet_tests ()
 
        local status=0
 
-       for testcase in $applet/*; do
-               if [ "$testcase" = "$applet/CVS" ]; then
+       for testcase in $srcdir/$applet/*; do
+               if [ "$testcase" = "$srcdir/$applet/CVS" ]; then
                        continue
                fi
 
@@ -78,20 +78,41 @@ run_applet_tests ()
 
 status=0
 
+if [ x"$1" = x"-v" ]; then
+       verbose=1
+       shift
+fi
+
 if [ $# -ne 0 ]; then
        applets="$@"
 else
-       applets="*"
+       applets=$(ls $srcdir)
 fi
 
 for applet in $applets; do
-       if [ "$applet" != CVS -a -d "$applet" ]; then
+       if [ "$applet" = "links" ]; then continue; fi
+       if [ "$applet" != "CVS" -a -d "$srcdir/$applet" ]; then
                if run_applet_tests $applet; then
                        :
                else
                        status=1
                fi
        fi
-done
+       applet=$(echo "$applet" | sed -n 's/\.tests$//p')
+       if [ ${#applet} -ne 0 ]
+       then
+               if [ -d links ]; then
+                       rm -f links/"$applet" 
+               else
+                       mkdir links 2> /dev/null
+               fi
+               ln -s ${bindir:-../..}/busybox links/"$applet"
+               PATH="$srcdir:$PATH" COMMAND="links/$applet" \
+                       "${srcdir:-.}/$applet".tests
+               if [ $? -ne 0 ]; then status=1; fi
+       fi
 
+done
+rm -f links/*
+rmdir links
 exit $status