X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;ds=inline;f=tests.lisp;h=4c741c643993ee7e57156f2ba418a8f32d3a34e3;hb=fd412a02bc5a599aa55e7f1737de2130118b7173;hp=d383dc08e15b68afcae02caba960333eefbc7f98;hpb=14c6c745a82935545327e1406e24ece6cccbaf98;p=jscl.git
diff --git a/tests.lisp b/tests.lisp
index d383dc0..4c741c6 100644
--- a/tests.lisp
+++ b/tests.lisp
@@ -1,17 +1,41 @@
-(defvar *passed-tests* 0)
-(defvar *failed-tests* 0)
+(defparameter *total-tests* 0)
+(defparameter *passed-tests* 0)
+(defparameter *failed-tests* 0)
+(defparameter *expected-failures* 0)
+(defparameter *unexpected-passes* 0)
+
+(defvar *use-html-output-p* t)
(defvar *timestamp* nil)
(defmacro test (condition)
- `(cond
- (,condition
- (write-line ,(concat "Test `" (prin1-to-string condition) "' passed"))
- (incf *passed-tests*))
- (t
- (write-line ,(concat "Test `" (prin1-to-string condition) "' failed."))
- (incf *failed-tests*))))
+ `(progn
+ (cond
+ (,condition
+ (format t "Test `~S' passed~%" ',condition)
+ (incf *passed-tests*))
+ (t
+ (if *use-html-output-p*
+ (format t "Test `~S' failed.~%" ',condition)
+ (format t "Test `~S' failed.~%" ',condition))
+ (incf *failed-tests*)))
+ (incf *total-tests*)))
+
+(defmacro expected-failure (condition)
+ `(progn
+ (cond
+ (,condition
+ (if *use-html-output-p*
+ (format t "Test `~S' passed unexpectedly!~%" ',condition)
+ (format t "Test `~S' passed unexpectedly!~%" ',condition))
+ (incf *unexpected-passes*))
+ (t
+ (format t "Test `~S' failed failed expectedly.~%" ',condition)
+ (incf *expected-failures*)))
+ (incf *total-tests*)))
+
+(defmacro test-equal (form value)
+ `(test (equal ,form, value)))
-(write-line "Running tests...")
-(write-line "")
+(format t "Running tests...~%~%")
(setq *timestamp* (get-internal-real-time))