X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=tests%2Fthreads.test.sh;h=c7d637435b4034340029ddde287aa960c5349541;hb=b15ec266a38f1dae4e52a46c1980d4b7259686d3;hp=5331e880d47ba893e41610545d8ee69d388f72c7;hpb=f7873f9a9edc6d39553106d0627b8ac270a1bfc4;p=sbcl.git diff --git a/tests/threads.test.sh b/tests/threads.test.sh index 5331e88..c7d6374 100644 --- a/tests/threads.test.sh +++ b/tests/threads.test.sh @@ -14,11 +14,20 @@ . ./subr.sh use_test_subdirectory +run_sbcl --eval '(sb-thread:return-from-thread t :allow-exit t)' +check_status_maybe_lose "return from main thread" $? 0 "ok" + +run_sbcl --eval '(sb-thread:abort-thread :allow-exit t)' +check_status_maybe_lose "abort main thread" $? 1 "ok" + +run_sbcl --eval '#+sb-thread (sb-thread:join-thread (sb-thread:make-thread (lambda () (sb-ext:exit :code 77)))) #-sb-thread (sb-ext:exit :code 77)' +check_status_maybe_lose "exit from normal thread" $? 77 "ok" + flag="condition-wait-sigcont.tmp" touch $flag # $! is not set correctly when calling run_sbcl, do it directly -"$SBCL_RUNTIME" --core "$SBCL_CORE" \ +"$SBCL_RUNTIME" --core "$SBCL_CORE" $SBCL_ARGS \ --load "$SBCL_PWD/condition-wait-sigcont.lisp" & sb_pid=$!