Reporters
The reporters allow to customize output of TSTyche.
This feature is available since TSTyche 3.0.
Usage
To specify a reporter, pass it with the --reporters
command line option:
tstyche --reporters list,tstyche-reporter,./custom-reporter.js
Or use the reporters
configuration option:
{
"reporters": ["list", "tstyche-reporter", "./custom-reporter.js"]
}
Built-in Reporters
By default, the built-in list
and summary
reporters are used.
list
If only one test file is selected, lists each test case and their status. Otherwise, only names of test files and their status are listed. The details of every failing test are included.
summary
Prints out a summary of all tests. It does not include any details of test failure. The summary is disabled in watch mode.
Custom Reporter
A custom reporter can be a package or a local module.
If you are publishing your reporter to npm
, use the following naming pattern: tstyche-*-reporter
.
The module must export a class that takes resolvedConfig
as a constructor argument and implements the on()
method:
export default class CustomReporter {
/**
* @param {import("tstyche/tstyche").ResolvedConfig} resolvedConfig
*/
constructor(resolvedConfig) {
this.resolvedConfig = resolvedConfig;
}
/**
* @param {import("tstyche/tstyche").ReporterEvent} reporterEvent
*/
on([event, payload]) {
if (event === "run:start") {
console.info("Hello from custom reporter!");
for (const task of payload.result.tasks) {
console.info(task.filePath);
}
}
}
}