X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=tests%2Fdefstruct.impure.lisp;h=1947bbd2c408caee16b9f2fa156de5376328c2d3;hb=7254da92a1ba1bf8bc5a2e78a29d993f272d526e;hp=1354ab60174d828c90f7b9250d2f70e5374178bb;hpb=3120740c3569735b00123b94b61679f56e253ea6;p=sbcl.git diff --git a/tests/defstruct.impure.lisp b/tests/defstruct.impure.lisp index 1354ab6..1947bbd 100644 --- a/tests/defstruct.impure.lisp +++ b/tests/defstruct.impure.lisp @@ -461,11 +461,13 @@ *manyraw*))) (room) (sb-ext:gc)) -(check-manyraws *manyraw*) +(with-test (:name defstruct-raw-slot-gc) + (check-manyraws *manyraw*)) ;;; try a full GC, too (sb-ext:gc :full t) -(check-manyraws *manyraw*) +(with-test (:name (defstruct-raw-slot-gc :full)) + (check-manyraws *manyraw*)) ;;; fasl dumper and loader also have special handling of raw slots, so ;;; dump all of them into a fasl @@ -485,7 +487,8 @@ ;;; re-read the dumped structures and check them (load "tmp-defstruct.manyraw.fasl") -(check-manyraws (dumped-manyraws)) +(with-test (:name (defstruct-raw-slot load)) + (check-manyraws (dumped-manyraws))) ;;;; miscellaneous old bugs @@ -1083,3 +1086,29 @@ redefinition." ;; So's empty. (eval '(defstruct (typed-struct2 (:type list) (:predicate)) (a 42 :type fixnum)))) + +(with-test (:name (:boa-supplied-p &optional)) + (handler-bind ((warning #'error)) + (eval `(defstruct (boa-supplied-p.1 (:constructor make-boa-supplied-p.1 + (&optional (bar t barp)))) + bar + barp))) + (let ((b1 (make-boa-supplied-p.1)) + (b2 (make-boa-supplied-p.1 t))) + (assert (eq t (boa-supplied-p.1-bar b1))) + (assert (eq t (boa-supplied-p.1-bar b2))) + (assert (eq nil (boa-supplied-p.1-barp b1))) + (assert (eq t (boa-supplied-p.1-barp b2))))) + +(with-test (:name (:boa-supplied-p &key)) + (handler-bind ((warning #'error)) + (eval `(defstruct (boa-supplied-p.2 (:constructor make-boa-supplied-p.2 + (&key (bar t barp)))) + bar + barp))) + (let ((b1 (make-boa-supplied-p.2)) + (b2 (make-boa-supplied-p.2 :bar t))) + (assert (eq t (boa-supplied-p.2-bar b1))) + (assert (eq t (boa-supplied-p.2-bar b2))) + (assert (eq nil (boa-supplied-p.2-barp b1))) + (assert (eq t (boa-supplied-p.2-barp b2)))))