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-ed function 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? These fine people already did:
Arne Brasseur, Alys Brooks, Rob Hanlon & Imre KószóEdit on GitHub
cljdoc builds & hosts documentation for Clojure/Script libraries
| Ctrl+k | Jump to recent docs | 
| ← | Move to previous article | 
| → | Move to next article | 
| Ctrl+/ | Jump to the search field |