X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=src%2Ffixture.lisp;h=2f559ec35736ad306de5d720ddde4a67d7661cca;hb=a3a3f45f2473649d64411e6e099c533c6c309fdd;hp=a3de037d246b5d95a2bb286ca056181e1ef1021e;hpb=1b24abf09e9fbb2a23c25a9583e5547514482f1b;p=fiveam.git diff --git a/src/fixture.lisp b/src/fixture.lisp index a3de037..2f559ec 100644 --- a/src/fixture.lisp +++ b/src/fixture.lisp @@ -1,6 +1,6 @@ ;; -*- lisp -*- -(in-package :it.bese.FiveAM) +(in-package :it.bese.fiveam) ;;;; ** Fixtures @@ -13,10 +13,25 @@ ;;;; '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.") +(defun get-fixture (key &optional default) + (gethash key *fixture* default)) + +(defun (setf get-fixture) (value key) + (when (gethash key *fixture*) + (warn "Redefining ~A in deflookup-table named ~S" + (let ((*package* (find-package :keyword))) + (format nil "~S" key)) + 'fixture)) + (setf (gethash key *fixture*) value)) + +(defun rem-fixture (key) + (remhash key *fixture*)) + (defmacro def-fixture (name 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