11 if [ -z "$JAVA" ] ; then
12 JAVA=../../../src/cacao/cacao
15 if [ -z "$TIMEOUT" ] ; then
19 if [ -n "$TIMEOUTPROG" ] ; then
20 if [ -x "$TIMEOUTPROG" ] ; then
21 echo "$0: using timeout program: $TIMEOUTPROG"
22 echo "$0: timeout value [s] : $TIMEOUT"
23 TIMEOUTRUN="$TIMEOUTPROG $TIMEOUT"
25 echo >&2 "$0: warning: timeout program not executable: $TIMEOUTPROG"
29 if [ -z "$TIMEOUTRUN" ] ; then
30 echo >&2 "$0: warning: running without timeout"
33 if [ "$1" = "--verbose" ] ; then
38 if [ "$1" = "--color" ] ; then
41 PASSCOLOR='\033[1;32m'
42 FAILCOLOR='\033[1;31m'
47 if [ -z "$JASMIN_JAR" ] ; then
48 JASMIN_JAR=/usr/share/java/jasmin-sable.jar
51 if [ ! -r "$JASMIN_JAR" ] ; then
52 echo >&2 "$0: warning: jasmin .jar is not available at $JASMIN_JAR"
56 JASMIN="$JAVA $JAVAFLAGS -cp $JASMIN_JAR jasmin.Main"
58 echo "java command: $JAVA $JAVAFLAGS"
59 echo "jasmin command: $JASMIN"
64 TESTBASENAME=$(basename "$TEST" .j)
67 TESTEXPECT="TESTEXPECT"
75 $JASMIN "$TEST" || exit 2
77 if grep 'ERROR:' "$TEST" >/dev/null ; then
79 EXPECTERROR=$(grep 'ERROR:.*' "$TEST" | sed 's,.*ERROR:[ \t]*,,')
84 $TIMEOUTRUN $JAVA $JAVAFLAGS "$TESTBASENAME" >"$TESTOUT" 2>"$TESTERR"
87 if [ $TESTSTATUS -ne $EXPECTSTATUS ] ; then
88 echo $ECHOFLAGS "${FAILCOLOR}FAIL: $TESTBASENAME - expected status $EXPECTSTATUS, but got $TESTSTATUS${NOCOLOR}"
92 if [ $EXPECTSTATUS -eq 0 ] ; then
93 grep 'OUTPUT:' "$TEST" | sed 's,.*OUTPUT:[ \t]*,,' >"$TESTEXPECT"
95 if diff -u "$TESTEXPECT" "$TESTOUT" ; then
96 if [ $TESTSTATUS -eq 0 ] ; then
97 echo $ECHOFLAGS "${PASSCOLOR}PASS: $TESTBASENAME${NOCOLOR}"
100 echo $ECHOFLAGS "${FAILCOLOR}FAIL: $TESTBASENAME - wrong output${NOCOLOR}"
104 if [ "$VERBOSE" -eq "1" ] ; then
105 $JAVA $JAVAFLAGS -sia "$TESTBASENAME" >"$TESTLOG" || exit 2
109 if grep "$EXPECTERROR" "$TESTERR" >/dev/null ; then
110 echo $ECHOFLAGS "${PASSCOLOR}PASS: $TESTBASENAME - got expected error: $EXPECTERROR${NOCOLOR}"
112 echo $ECHOFLAGS "${FAILCOLOR}FAIL: $TESTBASENAME - did not get expected error: $EXPECTERROR${NOCOLOR}"
120 rm -f "$TESTOUT" "$TESTEXPECT" "$TESTLOG" "$TESTERR"