@tapjs/before
A default tap plugin providing t.before()
.
USAGE
This plugin is installed with tap by default. If you had
previously removed it, you can tap plugin add @tapjs/before
to
bring it back.
import t from 'tap'
t.before(() => {
// this will run before the tests in this file start
})
If the method returns a promise, it will be awaited before moving on to the next test.
A t.before()
method will run prior to any subsequent child
tests. If it's called before any child tests have started, then
it will be run right away.
So, this test:
import t from 'tap'
t.before(() => {
console.error('before initial')
})
t.test('first test', t => {
t.before(async () => {
// this will wait before moving on
await new Promise(res => setTimeout(res, 100))
console.error('before in first test')
})
console.error('in first test')
t.test('child test', t => {
console.error('child of first test')
t.end()
})
t.end()
})
t.before(() => {
console.error('before between')
})
t.test('second test', t => {
console.error('in second test')
t.end()
})
will print:
before initial
in first test
before in first test
child of first test
before between
in second test
Essentially, t.before()
is a bit like a child test method that
doesn't get a Test
object as an argument.