X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=src%2Ftest.lisp;fp=src%2Ftest.lisp;h=b6e85dbd6d9a20de7088a19aec8f31c2fa97ae94;hb=7a016e70ee47507d22a59a3c7da1b1d3740d215e;hp=99bc8bbab54ff9c0568eb3cbdabbb224ba47a79c;hpb=71b6fc1cd91159a5ff28432701dea1fe85831df1;p=fiveam.git diff --git a/src/test.lisp b/src/test.lisp index 99bc8bb..b6e85db 100644 --- a/src/test.lisp +++ b/src/test.lisp @@ -46,8 +46,9 @@ If DEPENDS-ON is a symbol it is interpreted as `(AND depending on another. SUITE defaults to the current value of *SUITE*." - (destructuring-bind (name &key depends-on (suite nil suite-supplied-p)) + (destructuring-bind (name &key depends-on (suite nil suite-supplied-p) (compile-at :run-time)) (ensure-list name) + (declare (type (member :run-time :definition-time) compile-at)) (let (description) (setf description (if (stringp (car body)) (pop body) @@ -58,8 +59,10 @@ SUITE defaults to the current value of *SUITE*." :runtime-package ,*package* :test-lambda (lambda () - (funcall (let ((*package* ,*package*)) - (compile nil '(lambda () ,@body))))) + ,@(ecase compile-at + (:run-time `((funcall (let ((*package* ,*package*)) + (compile nil '(lambda () ,@body)))))) + (:definition-time body))) :description ,description :depends-on ',depends-on)) ,(if suite-supplied-p