@hackbg/spec
v1.0.0
Published
Tiny no-gimmicks test runner and reporter. Paired with @hackbg/ganesha, makes @hackbg/ensuite.
Downloads
8
Keywords
Readme
@hackbg/spec
Minimal test runner and reporter.
Its gimmick is that there are no gimmicks.
No describe
, no expect
, no beforeEach
/afterAll
, etc.
Who told you you needed those, anyway?
How to use
Define your test cases as plain old functions - synchronous or asynchronous, it's smart enough to handle both correctly, and you're smart enough to use JavaScript's standard control flow vocabulary.
Group test cases into specifications via regular ES modules (i.e. collect them all in an object and
export default
it.)
// spec1.spec.js
export default {
'synchronous test' (assert) {
assert(true)
},
async 'asynchronous test' (assert) {
await someAsyncFunction()
assert(true)
}
}
- Group specifications into a test suite in a single executable script
which calls
runSpec
on the test suite to execute the specifications. By default, it looks atprocess.argv.slice(2)
- if it's empty, it runs all specs. If it contains names of test suites, it runs only those.
// index.spec.js
import runSpec from '@hackbg/spec'
import Spec1 from './spec1.spec'
import Spec2 from './spec2.spec'
import Spec3 from './spec3.spec'
runSpec({ Spec1, Spec2, Spec3 })
node index.spec.js
node index.spec.js Spec1
node index.spec.js Spec2 Spec3
- Add the script to your project's
package.json
and run withnpm test
.
{
"scripts": {
"test": "node index.spec.js"
}
}
npm test
npm test Spec1
npm test Spec2 Spec3
- Goes well with Ganesha ;-)