Description

A lightweight unit test mechanism for Scheme.

Author

Neil W. Van Dyke

Version

Usage

(require-extension testeez)

Download

testeez.egg

Documentation

See the official documentation. There are a couple of additions for Chicken:

test clause: (test/equiv DESC EXPR EXPECTED (PRED ...))

Additional clause form which allows you to specify one or more custom equivalence predicates. You should either specify one predicate, which will be checked against every value expected; or N predicates, where N is the number of values expected. In the latter case, each predicate is checked only against its corresponding value.

The form (test/eq DESC EXPR EXPECTED) is exactly the same as (test/equiv DESC EXPR EXPECTED (eq?)).

This clause is non-public in the upstream version, but has been exposed since it seems useful. Its syntax is subject to change.

procedure: (%testeez:self-test)

See example below.

Examples

The following definition is made available as %testeez:self-test if the debug feature is registered at runtime.
For example, run csi -D debug -R testeez -eval "(%testeez:self-test)".

(define (%testeez:self-test)
  (testeez
   "Foo Station"

   (test/equal "Put two and two together" (+ 2 2) 4)

   (test-define "Bar function" bar (lambda (x) (+ x 42)))

   (test/equal "Bar scene" (bar 69) 0)  ;; will fail

   (test/eqv   "Full circle" (* (bar -21) 2) 42)

   (test/equal "Multiple"
               (values (+ 2 2) (string #\h #\i) (char-upcase #\p))
               (values 4 "hi" #\P))

   (test/equiv "Multiple predicates"
               (values (+ 2 2) (string #\h #\i) (char-upcase #\p))
               (values 4 "hi" #\P)
               (eqv? string=? char=?))))

Output:

#;1> (%testeez:self-test)

;;; BEGIN "Foo Station" TESTS

;; 1. Put two and two together
(+ 2 2)
;; ==> 4
;; Passed.

;; DEFINE: Bar function
(define bar (lambda (x) (+ x 42)))

;; 2. Bar scene
(bar 69)
;; ==> 111
;; FAILED!  Expected:
;;     0

;; 3. Full circle
(* (bar -21) 2)
;; ==> 42
;; Passed.

;; 4. Multiple
(values (+ 2 2) (string #\h #\i) (char-upcase #\p))
;; ==> 4
;;     "hi"
;;     #\P
;; Passed.

;; 5. Multiple predicates
(values (+ 2 2) (string #\h #\i) (char-upcase #\p))
;; ==> 4
;;     "hi"
;;     #\P
;; Passed.

;;; END "Foo Station" TESTS: FAILED
;;;     (Total: 5  Passed: 4  Failed: 1)

License

Copyright (c) 2005 Neil W. Van Dyke. This program is Free Software; you can
redistribute it and/or modify it under the terms of the GNU Lesser General
Public License as published by the Free Software Foundation; either version 2.1
of the License, or (at your option) any later version. This program is
distributed in the hope that it will be useful, but without any warranty;
without even the implied warranty of merchantability or fitness for a particular
purpose.  See <http://www.gnu.org/copyleft/lesser.html> for details.  For other
license options and consulting, contact the author.