;; -*- lisp -*-
-(in-package :it.bese.FiveAM)
+(in-package :it.bese.fiveam)
;;;; ** Fixtures
;;;; 'fixture' is so common in testing frameworks we've provided a
;;;; wrapper around defmacro for this purpose.
-(deflookup-table fixture
- :documentation "Lookup table mapping fixture names to fixture
+(defvar *fixture*
+ (make-hash-table :test 'eql)
+ "Lookup table mapping fixture names to fixture
objects.")
-(defmacro def-fixture (name args &body body)
+(defun get-fixture (key &optional default)
+ (gethash key *fixture* default))
+
+(defun (setf get-fixture) (value key)
+ (setf (gethash key *fixture*) value))
+
+(defun rem-fixture (key)
+ (remhash key *fixture*))
+
+(defmacro def-fixture (name (&rest args) &body body)
"Defines a fixture named NAME. A fixture is very much like a
macro but is used only for simple templating. A fixture created
with DEF-FIXTURE is a macro which can use the special macrolet
(setf (get-fixture ',name) (cons ',args ',body))
',name))
-(defmacro with-fixture (fixture-name args &body body)
+(defmacro with-fixture (fixture-name (&rest args) &body body)
"Insert BODY into the fixture named FIXTURE-NAME.
See Also: DEF-FIXTURE"
(assert (get-fixture fixture-name)
(fixture-name)
"Unknown fixture ~S." fixture-name)
- (destructuring-bind (largs &rest lbody) (get-fixture fixture-name)
+ (destructuring-bind ((&rest largs) &rest lbody)
+ (get-fixture fixture-name)
`(macrolet ((&body () '(progn ,@body)))
- (funcall (lambda ,largs ,@lbody) ,@args))))
+ (funcall (lambda (,@largs) ,@lbody) ,@args))))
;; Copyright (c) 2002-2003, Edward Marco Baringer
;; All rights reserved.