Simple Kaocha-based test runner implementation for Polylith.
Created as a demonstration for Polylith's pluggable test runner support , it can use custom Kaocha configuration from resources and allows for extensibility by providing a few hooks throughout the process.
This repository started out aiming to serve as an example implementation of a test runner that can be plugged into a Polylith workspace. The source code itself is organized into a Polylith workspace for the following reasons:
- So that it eats its own dogfood, that is, tests for this repository are executed using the product of it
- So that the author can practice setting up a Polylith repository
This repository is not intended to serve as a demonstration of a Polylith workspace and in places might not be fully idiomatic Polylith.
Alpha software. While breaking changes are not planned at this point, they should not come as a surprise.
For deps coordinates, see the Releases page. The current minimum version of the poly tool required by polylith-kaocha is v0.2.22-SNAPSHOT (345af4992b5ec97b712cd5b1a2a06f731cdfd61d)
. To set polylith-kaocha up with an older version of the poly tool, please see the docs at v0.8.3
or v0.8.4
of polylith-kaocha.
Add the following to the :poly
alias of the root deps.edn
in your Polylith
workspace, along with a reference to a version of polylith/clj-poly
which
includes pluggable test runner support:
{
:aliases
{:poly
{:extra-deps
{
polylith/clj-poly
{:git/url "https://github.com/polyfy/polylith"
:git/sha "345af4992b5ec97b712cd5b1a2a06f731cdfd61d"
:deps/root "projects/poly"}
polylith-kaocha/test-runner
{:git/url "https://github.com/imrekoszo/polylith-kaocha"
:git/tag ; see https://github.com/imrekoszo/polylith-kaocha/releases
:git/sha ; see https://github.com/imrekoszo/polylith-kaocha/releases
:deps/root "projects/test-runner"}
}}}}
After which you can configure your projects to be tested with it
in workspace.edn
:
{
;; To use it as the default test runner in the workspace
:test {:create-test-runner polylith-kaocha.test-runner/create}
:projects
{
;; To only use it for specific projects
"foo" {:test {:create-test-runner polylith-kaocha.test-runner/create}}
;; To revert to the default test runner only for specific projects
"bar" {:test {:create-test-runner :default}}
;; To use it in addition to the default test runner
"baz" {:test {:create-test-runner [:default polylith-kaocha.test-runner/create]}}
}
}
Unless configured otherwise, this test runner will try to invoke Kaocha's own commands via the wrapper in this workspace in the contexts of projects configured, the wrapper itself must be added as a test dependency for every such project:
{
:aliases
{:test
{:extra-deps
{
polylith-kaocha/kaocha-wrapper
{:git/url "https://github.com/imrekoszo/polylith-kaocha"
:git/tag ; see https://github.com/imrekoszo/polylith-kaocha/releases
:git/sha ; see https://github.com/imrekoszo/polylith-kaocha/releases
:deps/root "projects/kaocha-wrapper"}
}}}}
clojure -Srepro -M:poly test <poly test args>
To get debug output, use the :verbose
poly test arg.
Note
Due to how standalone
poly
tool installations are set up, those will not work with this plugin.
You need to runclojure -M:poly test
instead ofpoly test
.However, regardless of whether this plugin is used or not, I generally recommend setting up and using
poly
from an alias in every workspace to have better control over the exact version of the tool on a per-workspace basis.
Out of the box this applies the default Kaocha configuration which at this time
is to run clojure.test
tests. There are a few options to change this.
All the following settings can either be applied to the entire workspace, or specific projects by adding them to configuration:
{
:test {;; here to apply them to the entire workspace
}
:projects
{"foo" {:test {;; here to apply to specific projects
}}}
}
To supply your own Kaocha config , as a resource, put one on the classpath for all project-s that are to use it and set:
:polylith-kaocha/config-resource "resource/path/my-tests.edn"
Check the example
project and the namespaces
polylith-kaocha.kaocha-test-runner.core
and
polylith-kaocha.kaocha-wrapper.config
for how these are used
;; must be available on the project's classpath
:polylith-kaocha.kaocha-wrapper/post-load-config polylith-kaocha.example.hooks/post-load-config
:polylith-kaocha.kaocha-wrapper/post-enhance-config polylith-kaocha.example.hooks/post-enhance-config
:polylith-kaocha/tests-present? polylith-kaocha.example.hooks/tests-present?
:polylith-kaocha/run-tests polylith-kaocha.example.hooks/run-tests
;; must be available on the poly tool's classpath
:polylith-kaocha/runner-opts->kaocha-poly-opts polylith-kaocha.hooks/runner-opts->kaocha-poly-opts
- To use with hyperfiddle/rcf, see ieugen/poly-rcf and PR#7
This repository itself is a Polylith workspace, so those conventions, commands etc. mostly apply.
There are
some Babashka tasks
defined in bb.edn
to save some typing. Use bb tasks
to find out more.