Liking cljdoc? Tell your friends :D

polylith.clj.core.test-runner-contract.interface


ExternalTestRunnercljprotocol

Extends the TestRunner protocol to provide an external process namespace for a test runner. Polylith uses a classloader approach to run tests in isolation by default. ExternalTestRunner skips the classloaders and uses Java subprocesses.

Extends the `TestRunner` protocol to provide an external process namespace
for a test runner. Polylith uses a classloader approach to run tests in
isolation by default. `ExternalTestRunner` skips the classloaders and uses
Java subprocesses.

external-process-namespaceclj

(external-process-namespace this)

Returns a symbol or string identifying the main namespace of an external test runner. If it returns nil (default), the test runner will be an in-process test runner and the tests will run in an isolated classloader within the same process.

When an external test runner is used, the poly tool will not create a classloader. The external test runner implementation should use the all-paths argument passed to the run-tests function to create a classpath for the Java subprocesses.

The setup-fn and teardown-fn must be run by the external test runner instead of the poly tool.

Returns a symbol or string identifying the main namespace of an external
test runner. If it returns `nil` (default), the test runner will be an
in-process test runner and the tests will run in an isolated classloader
within the same process.

When an external test runner is used, the poly tool will not create a
classloader. The external test runner implementation should use the
`all-paths` argument passed to the run-tests function to create a classpath
for the Java subprocesses.

The setup-fn and teardown-fn must be run by the external test runner
instead of the poly tool.
sourceraw docstring

TestRunnercljprotocol

Implement this protocol to supply a custom test runner.

Runner options:

  • is-verbose A boolean indicating if we are running in verbose mode or not. TestRunner can use this to print additional information about the test run.
  • color-mode The color-mode that the poly tool is currently running with. TestRunner is expected to respect the color mode.
  • project A map containing the project information.
  • all-paths A vector of all paths necessary to create a classpath for running the tests in isolation within the context of the current project.
  • setup-fn An optional setup function for tests defined in the workspace config. The poly tool will run this function before calling run-tests only if this is an in-process TestRunner. If this is an ExternalTestRunner, the external test runner should run the setup-fn.
  • teardown-fn An optional teardown function for tests defined in the workspace config. The poly tool will run this function after the run-tests function completes (exception or not), only if this is an in-process TestRunner. If this is an ExternalTestRunner, the external test runner should run the teardown-fn.

Additional options for in-process TestRunner:

  • class-loader The isolated classloader created from the all-paths. This classloader will be used to evaluate statements within the project's context. Use this if you need more granular access. eval-in-project should be sufficient for most cases.
  • eval-in-project A function that takes a single form as its argument and evaluates it within the project's classloader. It returns the result of the evaluation. This is the primary interface for running tests in the project's isolated context.

Additional options for ExternalTestRunner:

  • process-ns The main namespace of the external test runner. This namespace will be invoked as a Java subprocess.

Usage: Create a constructor function that returns an instance of TestRunner or ExternalTestRunner:

(defn create [{:keys [workspace project test-settings is-verbose color-mode changes]}]
  ...

  (reify
    test-runner-contract/TestRunner
    (test-runner-name [this] ...)

    (test-sources-present? [this] ...)

    (tests-present? [this runner-opts] ...)

    (run-tests [this runner-opts] ...)

    ; Optional, only if you want an external test runner
    test-runner-contract/ExternalTestRunner
    (external-process-namespace [this] ...)))

workspace passed to the constructor will contain :user-input, which can be used to receive additional arguments for runtime configuration.

Add your constructor function in the workspace.edn. To add a single global test runner, use the :test key:

{:test {:create-test-runner my.namespace/create}
 :projects {"project-a" {:alias "a"}
            "project-b" {:alias "b"}}}

To add a multiple global test runners, use the vector variant inside the :test key. The following example will add three test runners globally where the last one is the default test runner.

{:test {:create-test-runner [my.namespace/create se.example/create :default]}
 :projects {"project-a" {:alias "a"}
            "project-b" {:alias "b"}}}

To add a custom test runner for a specific project, use the :test key in the project configuration. You can also add multiple test runners with using the vector variant.

{:projects {"project-a" {:alias "a"
                           :test {:create-test-runner my.namespace/create}}
            "project-b" {:alias "b"
                           :test {:create-test-runner [my.namespace/create
                                                       :default]}}}}

Adding a test runner definition to a project will override the global test runner. The project-a will use the global test runner, my.namespace/create whereas project-b will use the default test runner.

{:test {:create-test-runner my.namespace/create}
 :projects {"project-a" {:alias "a"}
            "project-b" {:alias "b"
                           :test {:create-test-runner :default}}}}
Implement this protocol to supply a custom test runner.

Runner options:
- `is-verbose`       A boolean indicating if we are running in verbose mode
                     or not. `TestRunner` can use this to print additional
                     information about the test run.
- `color-mode`       The color-mode that the poly tool is currently running with.
                     `TestRunner` is expected to respect the color mode.
- `project`          A map containing the project information.
- `all-paths`        A vector of all paths necessary to create a classpath for
                     running the tests in isolation within the context of the
                     current project.
- `setup-fn`         An optional setup function for tests defined in the
                     workspace config. The poly tool will run this function
                     before calling run-tests only if this is an in-process
                     `TestRunner`. If this is an `ExternalTestRunner`, the external
                     test runner should run the `setup-fn`.
- `teardown-fn`      An optional teardown function for tests defined in the
                     workspace config. The poly tool will run this function
                     after the run-tests function completes (exception or not),
                     only if this is an in-process `TestRunner`. If this is an
                     `ExternalTestRunner`, the external test runner should run
                     the `teardown-fn`.

Additional options for in-process `TestRunner`:
- `class-loader`     The isolated classloader created from the `all-paths`.
                     This classloader will be used to evaluate statements within
                     the project's context. Use this if you need more granular
                     access. `eval-in-project` should be sufficient for most
                     cases.
- `eval-in-project`  A function that takes a single form as its argument and
                     evaluates it within the project's classloader. It returns
                     the result of the evaluation. This is the primary interface
                     for running tests in the project's isolated context.

Additional options for `ExternalTestRunner`:
- `process-ns`       The main namespace of the external test runner. This
                     namespace will be invoked as a Java subprocess.

Usage:
Create a constructor function that returns an instance of `TestRunner` or
`ExternalTestRunner`:

```Clojure
(defn create [{:keys [workspace project test-settings is-verbose color-mode changes]}]
  ...

  (reify
    test-runner-contract/TestRunner
    (test-runner-name [this] ...)

    (test-sources-present? [this] ...)

    (tests-present? [this runner-opts] ...)

    (run-tests [this runner-opts] ...)

    ; Optional, only if you want an external test runner
    test-runner-contract/ExternalTestRunner
    (external-process-namespace [this] ...)))
```
`workspace` passed to the constructor will contain `:user-input`, which
can be used to receive additional arguments for runtime configuration.

Add your constructor function in the `workspace.edn`. To add a single global
test runner, use the `:test` key:

```Clojure
{:test {:create-test-runner my.namespace/create}
 :projects {"project-a" {:alias "a"}
            "project-b" {:alias "b"}}}
```

To add a multiple global test runners, use the vector variant inside the
`:test` key. The following example will add three test runners globally
where the last one is the default test runner.

```Clojure
{:test {:create-test-runner [my.namespace/create se.example/create :default]}
 :projects {"project-a" {:alias "a"}
            "project-b" {:alias "b"}}}
```

To add a custom test runner for a specific project, use the `:test` key
in the project configuration. You can also add multiple test runners with
using the vector variant.

```Clojure
{:projects {"project-a" {:alias "a"
                           :test {:create-test-runner my.namespace/create}}
            "project-b" {:alias "b"
                           :test {:create-test-runner [my.namespace/create
                                                       :default]}}}}
```

Adding a test runner definition to a project will override the global test
runner. The `project-a` will use the global test runner, `my.namespace/create`
whereas `project-b` will use the default test runner.

```Clojure
{:test {:create-test-runner my.namespace/create}
 :projects {"project-a" {:alias "a"}
            "project-b" {:alias "b"
                           :test {:create-test-runner :default}}}}
```

run-testsclj

(run-tests this runner-opts)

It should run the tests and throw an exception if the test run is considered failed.

It should run the tests and throw an exception if the test run is considered
failed.

test-runner-nameclj

(test-runner-name this)

Returns a printable name that the poly tool can print out for information purposes

Returns a printable name that the poly tool can print out for
information purposes

test-sources-present?clj

(test-sources-present? this)

The poly tool calls this first before attempting to run any tests. If it returns a falsy value, we short-circuit. Not even the project classloader will be created

The poly tool calls this first before attempting to run any tests. If
it returns a falsy value, we short-circuit. Not even the project
classloader will be created

tests-present?clj

(tests-present? this runner-opts)

The poly tool calls this before calling the run-tests. If it returns a falsy value, run-tests won't be called. The runner-opts passed to this function is identical to the one passed to the run-tests. It can evaluate forms in the project's context.

The poly tool calls this before calling the run-tests. If it returns a
falsy value, run-tests won't be called. The runner-opts passed to this
function is identical to the one passed to the run-tests. It can evaluate
forms in the project's context.
sourceraw docstring

cljdoc is a website building & hosting documentation for Clojure/Script libraries

× close