Kaocha can discover all of your fdefs and generate clojure.spec.test.check
tests for them. This saves you the trouble of writing your own boilerplate,
and gives you the truly "free" generative testing that clojure.spec promises.
There are two ways you can use this feature:
:kaocha.type/spec.test.check
test suites to your tests.edn
::kaocha.testable/type
= :kaocha.type/spec.test.check:kaocha/source-paths
: Normally your fdefs are with your code, so this
can probably be left defaulted at ["src"]
:kaocha.spec.test.check/checks
: Optional. If you want to
orchestrate multiple "sets" of checks with differing parameters, you can
specify them here. This is a collection of checks, each check being a map
which may contain the following optional keys:
:kaocha.spec.test.check/syms
: Currently your only options are either
:all-fdefs
(default) or to provide a set of the symbols for the fdefs
which you want to test. Eventually we will add :other-fdefs
to select
all the fdefs that were not specifically mentioned in other checks.:kaocha.spec.test.check/instrument?
Turn on orchestra instrumentation
during fdef checks:kaocha.spec.test.check/check-asserts?
Run s/check-asserts during fdef
checks:clojure.spec.test.check/opts
: A map containing any of:
:num-tests
: Test iterations per fdef:max-size
: Maximum length of generated collectionskaocha.plugin.alpha/spec-test-check
plugintests.edn
yourself,
you can also use this plugin to forceably override certain test
parameters:
--[no-]stc-instrumentation
= :kaocha.spec.test.check/instrument?
--[no-]stc-asserts
= :kaocha.spec.test.check/check-asserts?
--stc-num-tests NUM
= :num-tests
--stc-max-size SIZE
= :max-size
:no-gen
to :kaocha.filter/skip-meta
.
You might want to decorate an fdef with ^:no-gen
if there is either no
good generator for one or more of its arguments or if the function is
side-effectful.#kaocha/v1
{:tests [{:type :kaocha.type/spec.test.check
:id :generative-fdef-checks}]}
(ns sample
(:require [orchestra.core :refer [defn-spec]]))
(defn-spec ok-fn boolean? [x int?] true)
(defn-spec bad-fn boolean? [x int?] x)
When I run bin/kaocha --reporter kaocha.report/documentation --no-randomize --no-color
Then the output should contain:
--- generative-fdef-checks (clojure.spec.test.check) ---------------------------
sample
sample/bad-fn FAIL
sample/ok-fn
FAIL in sample/bad-fn (sample.clj:5)
== Checked sample/bad-fn ====================
-- Function spec failed -----------
(sample/bad-fn 0)
returned an invalid value.
0
should satisfy
boolean?
-------------------------
Detected 1 error
expected: boolean?
actual: 0
2 tests, 2 assertions, 1 failures.
(ns sample
(:require [orchestra.core :refer [defn-spec]]))
(defn-spec ok-fn keyword? [k keyword?] k)
(defn-spec bad-fn boolean? [k keyword?] (ok-fn k))
When I run bin/kaocha --reporter kaocha.report/documentation --no-randomize --no-color --plugin kaocha.plugin.alpha/spec-test-check
Then the output should contain:
sample
sample/bad-fn FAIL
sample/ok-fn
Can you improve this documentation?Edit on GitHub
cljdoc is a website building & hosting documentation for Clojure/Script libraries
× close