X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=src%2Ftest.lisp;h=2712d6a5ba439361d1e955dd753c09582fd43882;hb=d58c9adefaafa525332590fb38f9faefa4490612;hp=a8269c699dff7a639a6dbdd62bece8f2f9ff557c;hpb=869a1f5516006aba36b927d447206f686206fbc1;p=fiveam.git diff --git a/src/test.lisp b/src/test.lisp index a8269c6..2712d6a 100644 --- a/src/test.lisp +++ b/src/test.lisp @@ -74,19 +74,23 @@ If PROFILE is T profiling information will be collected as well." (destructuring-bind (name &rest args) (ensure-list fixture) `((with-fixture ,name ,args ,@body))) - body))) + body)) + (lambda-name + (format-symbol t "%~A-~A" '#:test name)) + (inner-lambda-name + (format-symbol t "%~A-~A" '#:inner-test name))) `(progn (setf (get-test ',name) (make-instance 'test-case :name ',name :runtime-package (find-package ,(package-name *package*)) :test-lambda - (lambda () + (named-lambda ,lambda-name () ,@ (ecase compile-at (:run-time `((funcall (let ((*package* (find-package ',(package-name *package*)))) - (compile nil '(lambda () - ,@effective-body)))))) + (compile ',inner-lambda-name + '(lambda () ,@effective-body)))))) (:definition-time effective-body))) :description ,description :depends-on ',depends-on