Tests
There are currently three types of tests:
- Unit tests, tests which are run to test regressions on code changes mostly through comparison to reference documents.
- Template tests, special tests for template packages which take a scaffold document and attempt to compile it and optionally compare it.
- Doc tests, example code in documentation comments which are compiled but not compared.
typst-test
can currently only operate on unit tests found as individual files in the test root.
In the future, template tests and doc tests will be added, see #34 and #49.
Tests get access to a special test library and can use annotations configuration.
Unit Tests
Unit tests are found in the test root as individual scripts and are the most versatile type of test. There are three kinds of unit tests:
- compile only, tests which are compiled, but not compared
- compared
- persistent, tests which are compared to reference persistent documents
- ephemeral, tests which are compared to the output of another script which is compiled on the fly
Each of those can be selected using one of the built-in test sets.
Unit tests are the only tests which have access to an extended Typst standard library. This extended standard library provides currently provides panic-helpers for catching and comparing panics.
A test is a directory somewhere within the test root (commonly <project>/tests
), which contains the following entries:
test.typ
: as the entry pointref.typ
(optional): for ephemeral tests as the reference entry pointref/
(optional, temporary): for persistent or ephemeral tests for the reference documentsout/
(temporary) for the test documentsdiff/
(temporary) for the diff documents
The path from the test root to the test script marks the test's identifier. Its test kind is determined by the existence of the ref script and ref directory:
- If it contains a
ref
directory but noref.typ
script, it is considered a persistent test. - If it a
ref.typ
script, it is considered an ephemeral test. - If it contains neither, it is considered compile only.
Tests may contain other tests at the moment, e.g the following is valid
tests/
foo
foo/test.typ
foo/bar
foo/bar/test.typ
and contains the tests foo
and foo/bar
.
Unit tests are compiled with the project root as typst root, such that they can easily access package internals.
They can also access test library items such as catch
for catching and binding panics for testing error reporting:
/// [annotation]
///
/// Description
// access to internals
#import "/src/internal.typ": foo
#let panics = () => {
foo("bar")
}
// ensures there's a panic
#assert-panic(panics)
// unwraps the panic if there is one
#assert.eq(
catch(panics).first(),
"panicked with: Invalid arg, expected `int`, got `str`",
)
Documentation Tests
TODO: See #34.
Template Tests
TODO: See #49.