From 3889078dbe09a9d85b359e9c0c0c225e0bbea343 Mon Sep 17 00:00:00 2001 From: Matt Kraai Date: Tue, 30 Oct 2001 23:11:20 +0000 Subject: Merge test suite. --- testsuite/runtest | 97 +++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 97 insertions(+) create mode 100755 testsuite/runtest (limited to 'testsuite/runtest') diff --git a/testsuite/runtest b/testsuite/runtest new file mode 100755 index 000000000..b19be3dd8 --- /dev/null +++ b/testsuite/runtest @@ -0,0 +1,97 @@ +#!/bin/sh + +PATH=$(dirname $(pwd)):$PATH + +run_applet_testcase () +{ + local applet=$1 + local testcase=$2 + + local status=0 + local U= + local X= + + 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" + return 0 + fi + + if grep -q "^# UNSUPPORTED: " $testcase; then + local feature=`sed -ne 's/.*UNSUPPORTED: //p' $testcase` + + if grep -q "^# ${feature} is not set$" ../.config; then + echo "UNSUPPORTED: $testname" + return 0 + fi + fi + + if grep -q "^# XFAIL$" $testcase; then + U=U + X=X + fi + + mkdir tmp + pushd tmp >/dev/null + + if . ../$testcase >/dev/null 2>&1; then + echo "${U}PASS: $testname" + if [ "$U" ]; then + status=1 + fi + else + echo "${X}FAIL: $testname" + if [ ! "$X" ]; then + status=1 + fi + fi + + popd >/dev/null + rm -rf tmp + + return $status +} + +run_applet_tests () +{ + local applet=$1 + + local status=0 + + for testcase in $applet/*; do + if [ "$testcase" = "$applet/CVS" ]; then + continue + fi + + if run_applet_testcase $applet $testcase; then + : + else + status=1 + fi + done + + return $status +} + + +status=0 + +if [ $# -ne 0 ]; then + applets="$@" +else + applets="*" +fi + +for applet in $applets; do + if [ "$applet" != CVS -a -d "$applet" ]; then + if run_applet_tests $applet; then + : + else + status=1 + fi + fi +done + +exit $status -- cgit v1.2.3