don't out \r to syslog
[oweals/busybox.git] / testsuite / runtest
index f57f464ee789384a1a9dffd450d0c2171b569019..4ac1d3bfed0b637ab5fe61383c26e2145446dc8c 100755 (executable)
@@ -1,23 +1,8 @@
 #!/bin/sh
 
-PATH=$(dirname $(pwd)):$PATH
-
-show_result ()
-{
-       local resolution=$1
-       local testcase=$2
-       local status=0
-
-       if [ $resolution = XPASS -o $resolution = FAIL ]; then
-               status=1
-       fi
-
-       if [ "$verbose" -o $status -eq 1 ]; then
-               echo "$resolution: $testcase"
-       fi
-
-       return $status
-}
+[ -n "$srcdir" ] || srcdir=$(pwd)
+[ -n "$bindir" ] || bindir=$(dirname $(pwd))
+PATH=$bindir:$PATH
 
 run_applet_testcase ()
 {
@@ -25,45 +10,40 @@ run_applet_testcase ()
        local testcase=$2
 
        local status=0
-       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
-               show_result UNTESTED $testname
+       if grep -q "^# CONFIG_${uc_applet} is not set$" $bindir/.config; then
+               echo UNTESTED: $testname
                return 0
        fi
 
        if grep -q "^# FEATURE: " $testcase; then
                local feature=`sed -ne 's/^# FEATURE: //p' $testcase`
 
-               if grep -q "^# ${feature} is not set$" ../.config; then
-                       show_result UNTESTED $testname
+               if grep -q "^# ${feature} is not set$" $bindir/.config; then
+                       echo UNTESTED: $testname
                        return 0
                fi
        fi
 
-       if grep -q "^# XFAIL$" $testcase; then
-               X=X
-       fi
-
        rm -rf tmp
        mkdir -p tmp
        pushd tmp >/dev/null
 
-       sh -x -e ../$testcase >.logfile.txt 2>&1
+       d=$srcdir sh -x -e $testcase >.logfile.txt 2>&1
 
        if [ $? != 0 ] ; then
-               show_result ${X}FAIL $testname
-               if [ "$verbose" == 1 ]; then
+               echo FAIL: $testname
+               if [ "$verbose" = 1 ]; then
                        cat .logfile.txt
-                       exit 1;
+                       #exit 1;
                fi;
                status=$?
        else
-               show_result ${X}PASS $testname
+               echo PASS: $testname
                rm -f .logfile.txt
                status=$?
        fi
@@ -80,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
 
@@ -106,17 +86,33 @@ 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