1.1.0 • Published 8 years ago
tap-flattener v1.1.0
tap-flattener
Flattens tap output including subtests into a single level hierarchy. Conforms to the same API and guarantees as tap-parser
Motivation
There are cases for TAP interop with other platforms where the entirety of the TAP 13 specification are not implemented. Specifically that subtests may not be supported given the many flavors possible. It is, however, also possible to "flatten" tap-output with subtests. e.g.:
$ cat test/fixtures/subtests.tap
TAP version 13
# Subtest: addition
ok 1 - 1 + 2 = 3
ok 2 - 5 + 5 = 10
ok 3 - 1 + 0 = 1
ok 4 - 1 + -1 = 0
1..4
ok 1 - addition # time=4.511ms
# Subtest: multiplication
ok 1 - 10 * 0 = 0
ok 2 - 10 * 1 = 10
ok 3 - 10 * 10 = 100
ok 4 - 10 * 0.5 = 5
1..4
ok 2 - multiplication # time=1.968ms
1..2
# time=14.141mswhen flattened would represent the same core eight assertions:
$ cat test/fixtures/subtests.tap | tap-flattener
TAP version 13
ok 1 - addition 1 + 2 = 3
ok 2 - addition 5 + 5 = 10
ok 3 - addition 1 + 0 = 1
ok 4 - addition 1 + -1 = 0
ok 5 - multiplication 10 * 0 = 0
ok 6 - multiplication 10 * 1 = 10
ok 7 - multiplication 10 * 10 = 100
ok 8 - multiplication 10 * 0.5 = 5
# time=14.141ms
1..8Usage
var Flatener = require('tap-flattener');
var flat = new Flatener(function (results) {
console.dir(results);
});
process.stdin.pipe(flat);CLI
This package also has a tap-flattener command.
Usage:
tap-flatener
Parses TAP data from stdin, and outputs the flattened TAP data to stdout.API
Under the covers, tap-flattener is writing to and reading from a tap-parser stream. As such it conforms to the same core API and named events. The two exceptions to this are:
- No
lineevents are emitted. Listen for individualassert,complete,plan, andversionevents instead. - No
childevents are emitted. The subtests represented by thesechildevents are instead transformed intoassertevents.
Run Tests
Tests are written with tap and can be run with npm:
npm test