In cucumber-js, Formatters ingest data about your test run in real time and then output content, either to the console or a file, in a useful format. (Some frameworks refer to this kind of thing as "reporters".)
cucumber-js provides many built-in Formatters, plus building blocks with which you can write your own.
You can specify one or more formats via the format
configuration option:
- In a configuration file
{ format: ['<TYPE[:PATH]>'] }
- On the CLI
$ cucumber-js --format <TYPE[:PATH]>
For each value you provide, TYPE
should be one of:
- The name of one of the built-in formatters (below) e.g.
progress
- A module/package name e.g.
@cucumber/pretty-formatter
- A relative path to a local formatter implementation e.g.
./my-customer-formatter.js
- An absolute path to a local formatter implementation in the form of a
file://
URL
If PATH
is supplied, the formatter prints to the given file, otherwise it prints to stdout
.
For example, this configuration would give you a progress bar as you run, plus JSON and HTML report files:
- In a configuration file
{ format: ['progress-bar', 'json:cucumber-report.json', 'html:cucumber-report.html'] }
- On the CLI
$ cucumber-js --format progress-bar --format json:cucumber-report.json --format html:cucumber-report.html
Some notes on specifying Formatters:
- If multiple formatters are specified with the same output, only the last is used.
- If no formatter for
stdout
is specified, we default to theprogress
formatter.
Many formatters, including the built-in ones, support some configurability via options. You can provide this data as an object literal via the formatOptions
configuration option, like this:
- In a configuration file
{ formatOptions: { someOption: true } }
- On the CLI
$ cucumber-js --format-options '{"someOption":true}'
This option is repeatable, so you can use it multiple times and the objects will be merged with the later ones taking precedence.
Some options offered by built-in formatters:
colorsEnabled
- see belowprintAttachments
- if set tofalse
, attachments won't be part of progress bars and summary reports
Many formatters, including the built-in ones, emit some colored output. By default, Cucumber will automatically detect the colors support of the output stream and decide whether to emit colors accordingly. This check comes via the supports-colors library and is pretty comprehensive, including awareness of commonly-used operating systems and CI platforms that represent edge cases.
If you'd like to override the auto-detection behaviour, you can provide the colorsEnabled
format option - either true
to forcibly emit colors, or false
to forcibly disable them.
It's worth noting that this option only influences output that Cucumber is in control of. Other tools in your stack such as assertion libraries might have their own way of handling colors. For this reason we'd recommend setting the FORCE_COLOR
environment variable if you want to forcibly enable (by setting it to 1
) or disable (by setting it to 0
) colors, as a variety of tools (including Cucumber) will honour it.
The Summary Formatter outputs a summary of the test run's results.
If everything passed, this will be short and sweet:
If there were issues, you'll see useful details including:
- Failed hooks or steps including error messages and stack traces
- Locations of any pending steps
- Snippets to implement any undefined steps
The Progress Formatter has the same output as the Summary Formatter at the end of the test run, but also provides concise real-time feedback each time a step or hook completes:
Similar to the Progress Formatter, but provides a real-time updating progress bar based on the total number of steps to be executed in the test run:
Note: the Progress Bar Formatter will only work with a TTY terminal (and not, for example, a file stream).
The HTML Formatter produces a rich interactive report bundled as a standalone HTML page:
You can:
- See detailed results including error messages and stack traces
- See attachments rendered in-place
- Filter to specific statuses
- Search by keywords or tag expressions
Outputs all the Cucumber Messages for the test run as newline-delimited JSON, which can then be consumed by other tools.
Outputs details of the test run in the legacy JSON format.
Note: this formatter is in maintenance mode and won't have new features added to it. Where you need a structured data representation of your test run, it's best to use the message
formatter. Tools that rely on this formatter will continue to work, but are encouraged to migrate to consume the message
output instead.
The JUnit formatter produces an XML-based report in the standard(ish) JUnit format. This is most commonly useful for having your CI platform pick up your tests results and factor them into its reporting. Consult your CI platform's docs for where exactly you should output this report to and what the filename should be.
The Snippets Formatter doesn't output anything regarding the test run; it just prints Snippets to implement any undefined steps. This is useful when you want to quickly zero in on the steps you have to implement and grab the snippet code for them in one go.
The Usage Formatter lists your step definitions and tells you about usages in your scenarios, including the duration of each usage, and any unused steps. Here's an example of the output:
┌───────────────────────────────────────┬──────────┬─────────────────────────────────┐
│ Pattern / Text │ Duration │ Location │
├───────────────────────────────────────┼──────────┼─────────────────────────────────┤
│ an empty todo list │ 760.33ms │ support/steps/steps.ts:6 │
│ an empty todo list │ 820ms │ features/empty.feature:4 │
│ an empty todo list │ 761ms │ features/adding-todos.feature:4 │
│ an empty todo list │ 700ms │ features/empty.feature:4 │
├───────────────────────────────────────┼──────────┼─────────────────────────────────┤
│ I add the todo {string} │ 432.00ms │ support/steps/steps.ts:10 │
│ I add the todo "buy some cheese" │ 432ms │ features/adding-todos.feature:5 │
├───────────────────────────────────────┼──────────┼─────────────────────────────────┤
│ my cursor is ready to create a todo │ 53.00ms │ support/steps/steps.ts:27 │
│ my cursor is ready to create a todo │ 101ms │ features/empty.feature:10 │
│ my cursor is ready to create a todo │ 5ms │ features/adding-todos.feature:8 │
├───────────────────────────────────────┼──────────┼─────────────────────────────────┤
│ no todos are listed │ 46.00ms │ support/steps/steps.ts:15 │
│ no todos are listed │ 46ms │ features/empty.feature:7 │
├───────────────────────────────────────┼──────────┼─────────────────────────────────┤
│ the todos are: │ 31.00ms │ support/steps/steps.ts:21 │
│ the todos are: │ 31ms │ features/adding-todos.feature:6 │
├───────────────────────────────────────┼──────────┼─────────────────────────────────┤
│ I remove the todo {string} │ UNUSED │ support/steps/steps.ts:33 │
└───────────────────────────────────────┴──────────┴─────────────────────────────────┘
Does what the Usage Formatter does, but outputs JSON, which can be output to a file and then consumed by other tools.
- @cucumber/pretty-formatter - prints the feature with inline results, colours and custom themes.