X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=tests%2Fmop.impure.lisp;h=6015c6652f7b23b2773ec20d761fe0952f693805;hb=1d9fe1f6d7d64aa05993d414c1cd683a2ce231cc;hp=96904b8f2117974e045d889821d6047439d0df11;hpb=1439811447104b32d986bab40d6e2ed431247004;p=sbcl.git diff --git a/tests/mop.impure.lisp b/tests/mop.impure.lisp index 96904b8..6015c66 100644 --- a/tests/mop.impure.lisp +++ b/tests/mop.impure.lisp @@ -645,5 +645,37 @@ ((foo :initarg :foo :reader foofoo :function car)) (:metaclass func-slot-class))) (assert (eq x (foofoo o))))) + +(defclass class-slot-removal-test () + ((instance :initform 1) + (class :allocation :class :initform :ok))) + +(defmethod update-instance-for-redefined-class ((x class-slot-removal-test) added removed plist &rest inits) + (throw 'update-instance + (list added removed plist inits))) + +(with-test (:name :class-redefinition-removes-class-slot) + (let ((o (make-instance 'class-slot-removal-test))) + (assert (equal '(nil nil nil nil) + (catch 'update-instance + (eval `(defclass class-slot-removal-test () + ((instance :initform 2)))) + (slot-value o 'instance)))))) + +(defclass class-slot-add-test () + ((instance :initform 1))) + +(defmethod update-instance-for-redefined-class ((x class-slot-add-test) added removed plist &rest inits) + (throw 'update-instance + (list added removed plist inits))) + +(with-test (:name :class-redefinition-adds-class-slot) + (let ((o (make-instance 'class-slot-add-test))) + (assert (equal '(nil nil nil nil) + (catch 'update-instance + (eval `(defclass class-slot-add-test () + ((instance :initform 2) + (class :allocation :class :initform :ok)))) + (slot-value o 'instance)))))) ;;;; success