-
Couldn't load subscription status.
- Fork 10
Description
I'm really liking 1am for its simplicity, but I think one addition could be very nice.
Right now, every test defined ends up in one big list. If different systems want to use 1am and not interfere with other systems, they copy the file into their project and change the package name. That workflow is simple and works well, but a bit more code reuse is, I think, desirable. To achieve that, there needs to be some way to differentiate collections of tests, or "test suites".
For a project I'm working on, I wanted different collections of tests even in the same system. I wrote a quick macro to facilitate that, DEFINE-TEST-FRAMEWORK. A package containing a test suite then only imports IS and SIGNALS from 1am, and contains a form like this:
(define-test-framework *my-tests* my-test my-run)The newly defined MY-TEST macro is then used to define new tests, and they are run using the new MY-RUN function. Different test "frameworks", as I called them here, don't interfere with eachother.
I think including something similar to this directly in 1am would be a good idea. Any thoughts?
The macro I whipped up:
(defmacro define-test-framework (tests-variable
test-macro
run-function)
"Define a variable to hold a list of tests, a macro to define tests and a
function to run the tests."
`(progn
(defvar ,tests-variable ())
(defmacro ,test-macro (name &body body)
`(let ((1am:*tests* ()))
(1am:test ,name ,@body)
(dolist (test 1am:*tests*)
(pushnew test ,',tests-variable))))
(defun ,run-function ()
(1am:run ,tests-variable))))