gulp-test-tools v0.6.2
gulp-test-tools
Testing tools for gulp
Usage
gulpRunner
(example.js)
var runner = require('gulp-test-tools').gulpRunner;
runner({ verbose: true })
.basedir(__dirname)
.chdir('test')
.gulp('build', '--gulpfile fixtures/gulpfile.js')
.run(cb);
function cb(err, stdout, stderr) {
...
}
$ node example.js
---- command
cd /home/sttk/project;
cd test;
node /usr/local/lib/node_modules/gulp-cli/bin/gulp.js build --gulpfile fixtures/gulpfile.js
---- error
null
---- stdout
[20:11:53] Working directory changed to ~/project/test/fixtures
[22:11:53] Using gulpfile ~/project/test/fixtures/gulpfile.js
[20:11:53] Starting 'build'...
[20:11:53] Finished 'build' after 5.11 ms
---- stderr
----.
eraseTime
(example.js)
var eraseTime = require('gulp-test-tools').eraseTime;
var gulpOutput =
"[20:11:53] Starting 'default'...\n" +
"[20:11:53] Finished 'default' after 5.11 ms\n";
console.log(eraseTime(gulpOutput));
$ node example.js
Starting 'default'...
Finished 'default' after 5.11 ms
eraseLapse
(example.js)
var eraseLapse = require('gulp-test-tools').eraseLapse;
var gulpOutput =
"[20:11:53] Starting 'default'...\n" +
"[20:11:53] Finished 'default' after 5.11 ms\n";
console.log(eraseLapse(gulpOutput));
$ node example.js
[20:11:53] Starting 'default'...
[20:11:53] Finished 'default' after ?
skipLines
(example.js)
var skipLines = require('gulp-test-tools').skipLines;
var gulpOutput =
"[20:11:53] Using gulpfile ~/project/gulpfile-2.js\n" +
"[20:11:53] Starting 'default'...\n" +
"[20:11:53] Finished 'default' after 5.11 ms\n";
console.log(skipLines(gulpOutput, 1));
$ node example.js
[20:11:53] Starting 'default'...
[20:11:53] Finished 'default' after 5.11 ms
headLines
(example.js)
var headLines = require('gulp-test-tools').headLines;
var gulpOutput =
"[20:11:53] Using gulpfile ~/project/gulpfile-2.js\n" +
"[20:11:53] Starting 'default'...\n" +
"Hello, world!\n" +
"[20:11:53] Finished 'default' after 5.11 ms\n";
console.log(headLines(gulpOutput, 1, 2));
$ node example.js
Hello, world!
How to use gulpRunner with istanbul
Though gulpRunner executes a command on a child process, it can get coverage about the command with istanbul. The way to get coverage is as follows:
$ istanbul cover example.js
If there are multiple test scripts, you can get their total coverage by following way:
$ istanbul cover example.js example2.js --print none && istanbul report lcov text-summary
If you run test scripts in the directory ./test
with istanbul + mocha, you should execute the following command:
$ istanbul cover _mocha --print none && istanbul report lcov text-summary
API
gulpRunner(opts)
Creates a gulp runner which generates a command string and runs it.
Arguments:
opts object : options for a runner. This object has following properties:
- verbose boolean : if
true
, prints command, err, stdout, stderr
- verbose boolean : if
Methods:
basedir(path)
Sets base directory path. This base directory is remained after running gulp.
Arguments:
- path string : a base directory path.
chdir(path , path ...)
Sets directory paths to be changed.
Arguments:
- path string : a sequence of directory paths.
gulp(arg , arg ...)
Sets gulp command with its arguments.
Arguments:
- arg string : a sequence of command line arguments.
run(cb)
Runs gulp command.
Arguments:
- cb function : a call back function which is passed result of execution.
eraseTime(text)
Returns a text which is erased timestamp of each line.
Arguments:
- text string : stdout text of gulp.
eraseLapse(text)
Returns a text which is erased lapse time of ease line.
Arguments:
- text string : stdout text of gulp.
skipLines(text, nSkip)
Returns a text which is skipped the specified number of lines.
Arguments:
headLines(text, nLine, nSkip)
Returns a first nLine
lines of a text. If second argument nSkip
is specified, first nSkip
lines are skipped.
Arguments:
- text string : stdout text of gulp.
- nLine number : line number to be output.
- nSkip number : line number to be skipped. (optional)
License
MIT