reagent/test/reagenttest/runtests.cljs

68 lines
2.1 KiB
Plaintext
Raw Normal View History

2016-05-01 13:45:37 +02:00
(ns reagenttest.runtests
(:require [reagenttest.testreagent]
[reagenttest.testcursor]
[reagenttest.testratom]
2015-09-12 18:34:10 +02:00
[reagenttest.testratomasync]
2015-09-19 19:03:29 +02:00
[reagenttest.testtrack]
2015-09-23 17:02:48 +02:00
[reagenttest.testwithlet]
[reagenttest.testwrap]
[reagent.impl.template-test]
[reagent.impl.util-test]
2019-12-17 14:32:45 +02:00
[clojure.test :as test]
[doo.runner :as doo :include-macros true]
[jx.reporter.karma :as karma]
2019-12-17 14:32:45 +02:00
[reagent.core :as r]))
2015-01-31 23:09:42 +01:00
2014-11-29 23:47:57 +01:00
(enable-console-print!)
2013-12-16 23:19:36 +01:00
(def test-results (r/atom nil))
2013-12-16 23:19:36 +01:00
(def test-box-style {:position 'absolute
:margin-left -35
:color :#aaa})
(defn all-tests []
(test/run-all-tests #"(reagenttest\.test.*|reagent\..*-test)"))
(defmethod test/report [::test/default :summary] [m]
;; ClojureScript 2814 doesn't return anything from run-tests
(reset! test-results m)
(println "\nRan" (:test m) "tests containing"
(+ (:pass m) (:fail m) (:error m)) "assertions.")
(println (:fail m) "failures," (:error m) "errors."))
(defn run-tests []
(reset! test-results nil)
(if r/is-client
(js/setTimeout all-tests 100)
(all-tests)))
(defn test-output-mini []
(let [res @test-results]
[:div {:style test-box-style
:on-click run-tests}
(if res
(if (zero? (+ (:fail res) (:error res)))
"All tests ok"
[:span "Test failure: "
(:fail res) " failures, " (:error res) " errors."])
"testing")]))
(defn init! []
;; This function is only used when running tests from the demo app.
;; Which is why exit-point is set manually.
(when (some? (test/deftest empty-test))
(doo/set-exit-point! (fn [success?] nil))
(run-tests)
[#'test-output-mini]))
;; Macro which sets *main-cli-fn*
(doo/doo-all-tests #"(reagenttest\.test.*|reagent\..*-test)")
(defn ^:export karma-tests [karma]
(karma/run-all-tests karma #"(reagenttest\.test.*|reagent\..*-test)"))
(when (exists? js/window)
(when-let [f (some-> js/window .-__karma__ .-loaded_real)]
(.loaded_real (.-__karma__ js/window))))