1
0
mirror of https://github.com/janet-lang/janet synced 2024-11-05 00:06:16 +00:00
janet/test/helper.janet

44 lines
1.2 KiB
Clojure
Raw Normal View History

2018-03-26 01:25:33 +00:00
# Helper code for running tests
(var num-tests-passed 0)
(var num-tests-run 0)
(var suite-num 0)
(var start-time 0)
2018-03-26 01:25:33 +00:00
2021-11-06 16:01:21 +00:00
(def is-verbose (os/getenv "VERBOSE"))
2020-01-16 04:38:06 +00:00
(defn assert
"Override's the default assert with some nice error handling."
2020-04-03 20:23:29 +00:00
[x &opt e]
(default e "assert error")
(++ num-tests-run)
(when x (++ num-tests-passed))
2020-09-27 17:18:12 +00:00
(def str (string e))
(def truncated
(if (> (length e) 40) (string (string/slice e 0 35) "...") (describe e)))
(if x
2021-11-06 16:01:21 +00:00
(when is-verbose (eprintf "\e[32m✔\e[0m %s: %v" truncated x))
(eprintf "\n\e[31m✘\e[0m %s: %v" truncated x))
x)
2018-03-26 01:25:33 +00:00
(defmacro assert-error
[msg & forms]
(def errsym (keyword (gensym)))
~(assert (= ,errsym (try (do ,;forms) ([_] ,errsym))) ,msg))
(defmacro assert-no-error
[msg & forms]
(def errsym (keyword (gensym)))
~(assert (not= ,errsym (try (do ,;forms) ([_] ,errsym))) ,msg))
2018-03-26 01:25:33 +00:00
(defn start-suite [x]
(set suite-num x)
(set start-time (os/clock))
2021-11-06 16:01:21 +00:00
(eprint "Running test suite " x " tests..."))
2018-03-26 01:25:33 +00:00
(defn end-suite []
(def delta (- (os/clock) start-time))
2021-11-06 16:01:21 +00:00
(eprintf "Test suite %d finished in %.3f seconds" suite-num delta)
(eprint num-tests-passed " of " num-tests-run " tests passed.")
(if (not= num-tests-passed num-tests-run) (os/exit 1)))