X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=tests%2Fscript.test.sh;h=e17761a5d04a226eb63e2b5191128a8e0b9d0287;hb=d27eb12b08a7eb445729bc339c9bedf0aeeaa4fa;hp=89693ff11150ccac3aafd059e9f436b6183d9aa2;hpb=f486d6af546bace9f7442d37cb7ff245d144aa81;p=sbcl.git diff --git a/tests/script.test.sh b/tests/script.test.sh index 89693ff..e17761a 100644 --- a/tests/script.test.sh +++ b/tests/script.test.sh @@ -18,14 +18,20 @@ use_test_subdirectory tmpscript=$TEST_FILESTEM.lisp-script +tmpout=$TEST_FILESTEM.lisp-out +tmperr=$TEST_FILESTEM.lisp-err echo '(quit :unix-status 7)' > $tmpscript run_sbcl --script $tmpscript check_status_maybe_lose "--script exit status from QUIT" $? 7 "(quit status good)" echo '(error "oops")' > $tmpscript -run_sbcl --script $tmpscript 2> /dev/null +run_sbcl --script $tmpscript 1> $tmpout 2> $tmperr check_status_maybe_lose "--script exit status from ERROR" $? 1 "(error implies 1)" +grep BACKTRACE $tmpout > /dev/null +check_status_maybe_lose "--script backtrace not to stdout" $? 1 "(ok)" +grep BACKTRACE $tmperr > /dev/null +check_status_maybe_lose "--script backtrace to stderr" $? 0 "(ok)" echo 'nil'> $tmpscript run_sbcl --script $tmpscript @@ -36,12 +42,40 @@ cat > $tmpscript < $tmpscript < $tmpout 2> $tmperr +check_status_maybe_lose "--script exit status when stdin closed" $? 0 "(as given)" +if [ -s $tmperr ] || [ "ONE" != `cat $tmpout` ] +then + echo "--script outputs wrong" + exit $EXIT_LOSE +fi + +cat > $tmpscript < $tmperr | head -n1 > $tmpout +check_status_maybe_lose "--script exit status when stdout closed" $? 0 "(as given)" +if [ -s $tmperr ] || [ "foo" != `cat $tmpout` ] +then + echo "--script unexpected error output" + exit $EXIT_LOSE +fi +echo '(write-line "Ok!")' | run_sbcl --script 1>$tmpout 2>$tmperr +check_status_maybe_lose "--script exit status script from stdin" $? 0 "(ok)" +if [ -s $tmperr ] || [ "Ok!" != `cat $tmpout` ] +then + echo "--script unexpected error output" + exit $EXIT_LOSE +fi + +rm -f $tmpscript $tmpout $tmperr exit $EXIT_TEST_WIN