2014-07-20 04:24:03 -04:00
|
|
|
|
(define-library (picrin test)
|
2015-07-08 13:21:57 -04:00
|
|
|
|
(import (scheme base)
|
|
|
|
|
(scheme write))
|
2014-09-08 04:08:38 -04:00
|
|
|
|
|
2014-07-20 04:24:03 -04:00
|
|
|
|
(define test-counter 0)
|
|
|
|
|
(define counter 0)
|
|
|
|
|
(define failure-counter 0)
|
|
|
|
|
|
|
|
|
|
(define fails '())
|
|
|
|
|
|
|
|
|
|
(define (print-statistics)
|
|
|
|
|
(newline)
|
|
|
|
|
(display "[0;34mTest Result: ")
|
|
|
|
|
(write (- counter failure-counter))
|
|
|
|
|
(display " / ")
|
|
|
|
|
(write counter)
|
|
|
|
|
(display " (")
|
|
|
|
|
(write (* (/ (- counter failure-counter) counter) 100))
|
|
|
|
|
(display "%)")
|
|
|
|
|
(display " [PASS/TOTAL]")
|
|
|
|
|
(display "[0;39m")
|
|
|
|
|
(newline)
|
|
|
|
|
(for-each
|
|
|
|
|
(lambda (fail)
|
|
|
|
|
(display fail))
|
2014-07-26 23:42:14 -04:00
|
|
|
|
(reverse fails)))
|
2014-07-20 04:24:03 -04:00
|
|
|
|
|
|
|
|
|
(define (test-begin . o)
|
|
|
|
|
(set! test-counter (+ test-counter 1)))
|
|
|
|
|
|
|
|
|
|
(define (test-end . o)
|
|
|
|
|
(set! test-counter (- test-counter 1))
|
|
|
|
|
(if (= test-counter 0)
|
|
|
|
|
(print-statistics)))
|
|
|
|
|
|
|
|
|
|
(define-syntax test
|
|
|
|
|
(syntax-rules ()
|
|
|
|
|
((test expected expr)
|
2015-07-21 02:16:04 -04:00
|
|
|
|
(test expected expr equal?))
|
|
|
|
|
((test expected expr =)
|
2017-03-30 04:42:02 -04:00
|
|
|
|
(begin
|
2014-07-20 04:24:03 -04:00
|
|
|
|
(display "case ")
|
|
|
|
|
(write counter)
|
2017-03-30 04:42:02 -04:00
|
|
|
|
(let ((res (call/cc
|
|
|
|
|
(lambda (k)
|
|
|
|
|
(with-exception-handler
|
|
|
|
|
(lambda (e) (k (cons 'raised e)))
|
|
|
|
|
(lambda ()
|
|
|
|
|
(cons #f expr)))))))
|
|
|
|
|
(if (eq? (car res) 'raised)
|
|
|
|
|
(let ((out (open-output-string)))
|
|
|
|
|
(display " [0;31mERROR: " out)
|
|
|
|
|
(write 'expr out)
|
|
|
|
|
(newline out)
|
|
|
|
|
(display " expected " out)
|
|
|
|
|
(write expected out)
|
|
|
|
|
(display " but got an error " out)
|
|
|
|
|
(write (cdr res) out)
|
|
|
|
|
(display "[0;39m" out)
|
|
|
|
|
(newline out)
|
|
|
|
|
(let ((str (get-output-string out)))
|
|
|
|
|
(set! fails (cons str fails))
|
|
|
|
|
(display str)))
|
|
|
|
|
(let ((res (cdr res)))
|
|
|
|
|
(if (= res expected)
|
|
|
|
|
(begin
|
|
|
|
|
(display "[0;32m PASS: ")
|
|
|
|
|
(write 'expr)
|
|
|
|
|
(display " equals ")
|
|
|
|
|
(write expected)
|
|
|
|
|
(display "[0;39m")
|
|
|
|
|
(newline))
|
|
|
|
|
(begin
|
|
|
|
|
(set! failure-counter (+ failure-counter 1))
|
|
|
|
|
(let ((out (open-output-string)))
|
|
|
|
|
(display " [0;31mFAIL: " out)
|
|
|
|
|
(write 'expr out)
|
|
|
|
|
(newline out)
|
|
|
|
|
(display " expected " out)
|
|
|
|
|
(write expected out)
|
|
|
|
|
(display " but got " out)
|
|
|
|
|
(write res out)
|
|
|
|
|
(display "[0;39m" out)
|
|
|
|
|
(newline out)
|
|
|
|
|
(let ((str (get-output-string out)))
|
|
|
|
|
(set! fails (cons str fails))
|
|
|
|
|
(display str)))))))
|
|
|
|
|
(set! counter (+ counter 1)))))))
|
2014-07-20 04:24:03 -04:00
|
|
|
|
|
|
|
|
|
(define-syntax test-values
|
|
|
|
|
(syntax-rules ()
|
|
|
|
|
((_ expect expr)
|
2014-07-21 09:56:53 -04:00
|
|
|
|
(test (call-with-values (lambda () expect) (lambda results results))
|
2014-07-20 04:24:03 -04:00
|
|
|
|
(call-with-values (lambda () expr) (lambda results results))))))
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
(define (test-failure-count)
|
|
|
|
|
(length fails))
|
|
|
|
|
|
|
|
|
|
(define-syntax test-syntax-error
|
|
|
|
|
(syntax-rules ()
|
|
|
|
|
((_) (syntax-error "invalid use of test-syntax-error"))))
|
|
|
|
|
|
2015-01-17 10:32:52 -05:00
|
|
|
|
(export test test-begin test-end test-values test-syntax-error))
|