X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=tests%2Fscript.test.sh;h=b209d96faa4c9ede76de5271c58d515a83e1794c;hb=31f68584d0732dc0d17f379773e5f87f1e5a78ad;hp=e17761a5d04a226eb63e2b5191128a8e0b9d0287;hpb=4993cd552cc06b6889a2b1898448cb2687ed0b6c;p=sbcl.git diff --git a/tests/script.test.sh b/tests/script.test.sh index e17761a..b209d96 100644 --- a/tests/script.test.sh +++ b/tests/script.test.sh @@ -18,19 +18,20 @@ use_test_subdirectory tmpscript=$TEST_FILESTEM.lisp-script +tmpfasl=$TEST_FILESTEM.lisp-fasl tmpout=$TEST_FILESTEM.lisp-out tmperr=$TEST_FILESTEM.lisp-err -echo '(quit :unix-status 7)' > $tmpscript +echo '(exit :code 7)' > $tmpscript run_sbcl --script $tmpscript -check_status_maybe_lose "--script exit status from QUIT" $? 7 "(quit status good)" +check_status_maybe_lose "--script exit status from EXIT" $? 7 "(status good)" echo '(error "oops")' > $tmpscript 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 +grep Backtrace $tmpout > /dev/null check_status_maybe_lose "--script backtrace not to stdout" $? 1 "(ok)" -grep BACKTRACE $tmperr > /dev/null +grep Backtrace $tmperr > /dev/null check_status_maybe_lose "--script backtrace to stderr" $? 0 "(ok)" echo 'nil'> $tmpscript @@ -38,14 +39,32 @@ run_sbcl --script $tmpscript check_status_maybe_lose "--script exit status from normal exit" $? 0 "(everything ok)" cat > $tmpscript </dev/null +check_status_maybe_lose "--script exit status from QUIT when standard-output closed" $? 3 "(as given)" +run_sbcl --load $tmpscript >/dev/null +check_status_maybe_lose "--load exit status from QUIT when standard-output closed" $? 3 "(as given)" + +cat > $tmpscript </dev/null +check_status_maybe_lose "--script exit status from QUIT when original standard-output closed" $? 3 "(as given)" +run_sbcl --load $tmpscript >/dev/null +check_status_maybe_lose "--load exit status from QUIT when original standard-output closed" $? 3 "(as given)" + +cat > $tmpscript </dev/null +check_status_maybe_lose "--script exit status from EXIT when stdout closed" $? 3 "(as given)" +run_sbcl --load $tmpscript >/dev/null +check_status_maybe_lose "--load exit status from EXIT when stdout closed" $? 3 "(as given)" cat > $tmpscript <$tmpout 2>$tmperr -check_status_maybe_lose "--script exit status script from stdin" $? 0 "(ok)" +check_status_maybe_lose "--script exit status 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 +# --script +cat > $tmpscript < $tmpout +if [ "`grep -c :SCRIPT-OK $tmpout`" != 1 ] ; then + echo "failed --script test using PRINT" + exit $EXIT_LOSE +fi + +# automatically executing fasls +# +# this test is fragile, with its SBCL_HOME hack to get the shebang +# line in the fasl to find the right core, and also is unlikely to +# work with that mechanism on Windows. +echo '(format t "Hello, Fasl~%")' > $tmpscript +run_sbcl --eval "(compile-file \"$tmpscript\" :output-file \"$tmpfasl\")" /dev/null +chmod +x $tmpfasl +SBCL_HOME=`dirname $SBCL_CORE` ./$tmpfasl >$tmpout 2>$tmperr +check_status_maybe_lose "--script exit status from fasl" $? 0 "(ok)" +if [ -s $tmperr ] || [ "Hello, Fasl" != "`cat $tmpout`" ] +then + echo "--script from fasl unexpected output" + exit $EXIT_LOSE +fi + +rm -f $tmpscript $tmpout $tmperr $tmpfasl exit $EXIT_TEST_WIN