X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=tests%2Falien.impure.lisp;h=fe5c18ee3d99ae68e301f50705c35e851521662f;hb=3d46727f4b73a63c788c143efb1f196c153af371;hp=b327577dd8141aca25ce9dccfa7c2109928cf7d1;hpb=e7476d980c0b4949c9416b59249d0d621c0f747d;p=sbcl.git diff --git a/tests/alien.impure.lisp b/tests/alien.impure.lisp index b327577..fe5c18e 100644 --- a/tests/alien.impure.lisp +++ b/tests/alien.impure.lisp @@ -20,8 +20,8 @@ ;;; In sbcl-0.6.10, Douglas Brebner reported that (SETF EXTERN-ALIEN) ;;; was messed up so badly that trying to execute expressions like ;;; this signalled an error. -(setf (sb-alien:extern-alien "current_control_stack_pointer" sb-alien:unsigned) - (sb-alien:extern-alien "current_control_stack_pointer" sb-alien:unsigned)) +(setf (sb-alien:extern-alien "thread_control_stack_size" sb-alien:unsigned) + (sb-alien:extern-alien "thread_control_stack_size" sb-alien:unsigned)) ;;; bug 133, fixed in 0.7.0.5: Somewhere in 0.pre7.*, C void returns ;;; were broken ("unable to use values types here") when @@ -264,8 +264,7 @@ ((foo (unsigned 32))) foo) -#+(or x86-64 x86) -(with-test (:name bug-316325) +(with-test (:name bug-316325 :skipped-on '(not (or :x86-64 :x86))) ;; This test works by defining a callback function that provides an ;; identity transform over a full-width machine word, then calling ;; it as if it returned a narrower type and checking to see if any @@ -294,4 +293,43 @@ (verify (signed 16) #x003f8042 #x-7fbe) (verify (signed 16) #x003f7042 #x7042))) +(with-test (:name :bug-654485) + ;; DEBUG 2 used to prevent let-conversion of the open-coded ALIEN-FUNCALL body, + ;; which in turn led the dreaded %SAP-ALIEN note. + (handler-case + (compile nil + `(lambda (program argv) + (declare (optimize (debug 2))) + (with-alien ((sys-execv1 (function int c-string (* c-string)) :extern + "execv")) + (values (alien-funcall sys-execv1 program argv))))) + (compiler-note (n) + (error "bad note: ~A" n)))) + +(with-test (:name :bug-721087) + (assert (typep nil '(alien c-string))) + (assert (not (typep nil '(alien (c-string :not-null t))))) + (assert (eq :ok + (handler-case + (posix-getenv nil) + (type-error (e) + (when (and (null (type-error-datum e)) + (equal (type-error-expected-type e) + '(alien (c-string :not-null t)))) + :ok)))))) + +(with-test (:name :make-alien-string) + (let ((alien (sb-alien::make-alien-string "This comes from lisp!"))) + (gc :full t) + (assert (equal "This comes from lisp!" (cast alien c-string))) + (free-alien alien))) + +(with-test (:name :malloc-failure) + (assert (eq :enomem + (handler-case + (loop repeat 128 + collect (sb-alien:make-alien char (1- array-total-size-limit))) + (storage-condition () + :enomem))))) + ;;; success