X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=contrib%2Fsb-posix%2Fsb-posix.asd;h=14892c12edab01977750fcd13d63a6dada5982ab;hb=9fb8bf2eb2c91cbda313edaa3362ff8b221ab81d;hp=2a7252e8039e903a70724ee278113953eb65364d;hpb=f5f4dc4eb88fd23d8fb835c21ca862274d26c18e;p=sbcl.git diff --git a/contrib/sb-posix/sb-posix.asd b/contrib/sb-posix/sb-posix.asd index 2a7252e..14892c1 100644 --- a/contrib/sb-posix/sb-posix.asd +++ b/contrib/sb-posix/sb-posix.asd @@ -1,20 +1,49 @@ ;;; -*- Lisp -*- -(require :sb-grovel) +(cl:eval-when (:compile-toplevel :load-toplevel :execute) + (asdf:oos 'asdf:load-op :sb-grovel)) (defpackage #:sb-posix-system (:use #:asdf #:cl #:sb-grovel)) (in-package #:sb-posix-system) (defsystem sb-posix :depends-on (sb-grovel) + #+sb-building-contrib :pathname + #+sb-building-contrib "SYS:CONTRIB;SB-POSIX;" :components ((:file "defpackage") (:file "designator" :depends-on ("defpackage")) - (:file "macros" :depends-on ("defpackage")) + (:file "macros" :depends-on ("designator")) (sb-grovel:grovel-constants-file "constants" + :do-not-grovel #.(progn #-sb-building-contrib t) :package :sb-posix :depends-on ("defpackage")) (:file "interface" :depends-on ("constants" "macros" "designator")))) -(defmethod perform :after ((o test-op) (c (eql (find-system :sb-posix)))) +(defsystem sb-posix-tests + :depends-on (sb-rt) + :components ((:file "posix-tests"))) + +(defmethod perform :after ((o load-op) (c (eql (find-system :sb-posix)))) (provide 'sb-posix)) (defmethod perform ((o test-op) (c (eql (find-system :sb-posix)))) - t) + (operate 'load-op 'sb-posix-tests) + (operate 'test-op 'sb-posix-tests)) + +(defmethod perform ((o test-op) (c (eql (find-system :sb-posix-tests)))) + (funcall (intern "DO-TESTS" (find-package "SB-RT"))) + (let ((failures (funcall (intern "PENDING-TESTS" "SB-RT"))) + (ignored-failures (loop for sym being the symbols of :sb-posix-tests + if (search ".ERROR" (symbol-name sym)) + collect sym))) + (cond + ((null failures) + t) + ((null (set-difference failures ignored-failures)) + (warn "~@") + t) + (t + (error "non-errno tests failed!")))))