Node test utility
lab is a simple test utility for node. Unlike other test frameworks, lab does not attempt to cover many use cases or provide rich functionality and extensibility. In fact, this project started as a fork off mocha and was repeatedly refactored until only the very basic functionality was left which was then rewritten into a handful of functions.
lab's primary goal is to support the narrow use cases of the spumko modules. If you give it a try and find a missing feature, you are better off giving mocha a try. We are unlikely to add functionality to it. It is not meant to be a framework, just a handy utility.
lab borrows heavily from mocha, including the actual code used to render the coverage report into HTML. mocha is a comprehensive test framework created by TJ Holowaychuk and published under the MIT license.
To install lab:
$ npm install lab
To start:
$ lab
By default, lab loads all the '*.js' files inside the local 'test' directory and executes the tests found. To start lab using different directories or files, pass those as arguments:
$ lab unit.js
Test files must require the lab module, and add tests using the 'test()' method:
var Lab = require('lab');
Lab.test('returns true when 1 + 1 equals 2', function (done) {
Lab.expect(1+1).to.equal(2);
done();
});
When a test is completed, 'done()' must be called, otherwise the test will time out (2 seconds by default) and will fail. The test passes if 'done()' is call once before the timeout, and no exception thrown.
lab works with any test utility that throws an error when a condition isn't met. It uses the same error interface as mocha and already includes chai's 'expect()' in its exported interface as shown above.
Tests can be organized into experiments:
var Lab = require('lab');
Lab.experiment('math', function () {
Lab.test('returns true when 1 + 1 equals 2', function (done) {
Lab.expect(1+1).to.equal(2);
done();
});
});
If you need to perform some asynch actions before or after executing the tests inside an experiment, the 'before()' and 'after()' methods can be used:
var Lab = require('lab');
Lab.experiment('math', function () {
Lab.before(function (done) {
// Wait 1 second
setTimeout(function () { done(); }, 1000);
});
Lab.test('returns true when 1 + 1 equals 2', function (done) {
Lab.expect(1+1).to.equal(2);
done();
});
});
To make lab look like BDD:
var Lab = require('lab');
var describe = Lab.experiment;
var it = Lab.test;
var expect = Lab.expect;
var before = Lab.before;
var after = Lab.after;
describe('math', function () {
it('returns true when 1 + 1 equals 2', function (done) {
expect(1+1).to.equal(2);
done();
});
});
To make lab look like TDD:
var Lab = require('lab');
var suite = Lab.experiment;
var test = Lab.test;
var expect = Lab.expect;
var before = Lab.before;
var after = Lab.after;
suite('math', function () {
test('returns true when 1 + 1 equals 2', function (done) {
expect(1+1).to.equal(2);
done();
});
});
lab supports the following command line options:
-r
- the reporter used to generate the test results. Defaults toconsole
. Options are:console
- simple text output to consolecoverage
- JSON code coverage reporthtml
- HTML code coverage reportthreshold
- Code coverage percentage check
-m
- individual tests timeout in milliseconds, defaults to 2 seconds-o
- file to save the report to (html
only), otherwise sent to stdout-t
- minimum code test coverage percentage (threshold
only), defaults to 100%-e
- value to set theNODE_ENV
environment variable to, defaults to 'test'-g
- determines if global variable leak checking is enabled or not. To disable pass 0 and to enable pass 1. Defaults to enabled.
lab was developed to provide a minimal layer above writing simple node test cases. In contrast with other test frameworks, lab does not modify any prototypes, globals, and uses node domains to capture test errors. We've used other test frameworks and utilities but at some point needed greater control over the tools, especially around domains and error handling in node.