Regression test
1. Source structure
. ├── unit │ └── … └── compose └── … ├── [enabled] → applicability ├── [env] → environment setup ├── [rc] → configuration ├── [in] → start file ├── cmd → command ├── [script] → UI automation ├── [out] → expected end file ├── [kak_*] → expected expansion values └── [error] → expected error
2. Usage
To test, just type run [test]
in the test
directory.
It will print each passing test. If a test fails, a unified context diff
is printed showing the test’s expected output and the actual output.
3. Details
enabled
is optional.
If it exists and is executable,
it is invoked with no parameters.
If it exits with a non-zero exit code,
the test is assumed to be not applicable to the current environment
(for example, a test for OS-specific integration
isn’t useful on a different OS)
and will be silently skipped.
env
is optional.
If it exists, it will be sourced before starting Kakoune.
rc
is optional
and should contain a sequence of commands,
e.g., set-option
, define-command
, declare-option
.
rc
is sourced and evaluated before the cmd
key sequence is executed.
in
is optional
and should contain the initial text loaded into the input buffer
for editing by the cmd
key sequence.
cmd
is required
and should contain a key sequence that will edit the input buffer.
cmd
is executed after the rc
command sequence is sourced.
script
is optional
and is a shell-script that will be sourced after cmd
is executed.
The special ui_in
function sends a string
(expected to be a JSON UI message,
see doc/json_ui.asciidoc
in the Kakoune source)
to the running Kakoune instance,
while the special ui_out
function
checks the next JSON UI messages from Kakoune
against its arguments,
and fails the test if any of them are different.
You can also say ui_out -ignore N
to ignore the next N JSON UI messages,
where N is a positive integer.
out
is optional
and should contain the expected text generated by the cmd
key sequence.
If the actual out
text
does not match the expected content in the corresponding file,
the unit test will fail.
If there is no out
then the unit test will always succeed.
Any kak_*
files should match the corresponding expansion
after cmd
is complete.
For example, a file named kak_selection_desc
should match the %val{selection_desc}
expansion.
See :doc expansions
for a list of available expansions.
If there is an error
file,
the test is expected to produce an error.
If Kakoune exits successfully,
or if it fails with the wrong error,
the test is marked as a failure.