Package Exports
- grunt-espower
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (grunt-espower) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
grunt-espower
A grunt task to apply espower to target files.
DESCRIPTION
grunt-espower
is a grunt task to instrument "Power Assert" feature into your code.
Internally, grunt-espower
task uses espower
module that manipulates assertion expression (JavaScript Code) represented as Mozilla JavaScript AST, to instrument power-assert feature into the code. The magic is done by using Esprima and Escodegen.
Please note that grunt-espower
is a beta version product. Pull-requests, issue reports and patches are always welcomed. See power-assert project for more documentation.
Getting Started
This plugin requires Grunt ~0.4.1
If you haven't used Grunt before, be sure to check out the Getting Started guide, as it explains how to create a Gruntfile as well as install and use Grunt plugins. Once you're familiar with that process, you may install this plugin with this command:
npm install grunt-espower --save-dev
Once the plugin has been installed, it may be enabled inside your Gruntfile with this line of JavaScript:
grunt.loadNpmTasks('grunt-espower');
The "espower" task
Overview
In your project's Gruntfile, add a section named espower
to the data object passed into grunt.initConfig()
.
grunt.initConfig({
espower: {
options: {
// Task-specific options go here.
},
your_target: {
// Target-specific file lists and/or options go here.
},
},
})
Options
options.destructive
Type: Boolean
Default value: false
Instrument target AST destructively or not.
options.powerAssertVariableName
Type: String
Default value: 'assert'
Target variable name to instrument.
options.lineSeparator
Type: String
Default value: '\n'
Line separator in target sources.
options.targetMethods
Type: Object
Default value:
targetMethods: {
oneArg: [
'ok'
],
twoArgs: [
'equal',
'notEqual',
'strictEqual',
'notStrictEqual',
'deepEqual',
'notDeepEqual'
]
}
Target assertion methods to insrtument.
oneArg
array for assertion methods with a expression argument (likeassert.ok(actual)
)twoArgs
array for assertion methods with two expression arguments (likeassert.equal(actual, expected)
)
Usage Examples
Default Options
grunt.initConfig({
espower: {
test: {
files: [
{
expand: true, // Enable dynamic expansion.
cwd: 'test/', // Src matches are relative to this path.
src: ['**/*.js'], // Actual pattern(s) to match.
dest: 'espowered/', // Destination path prefix.
ext: '.js' // Dest filepaths will have this extension.
}
]
},
},
})
Custom Options
grunt.initConfig({
espower: {
demo: {
options :{
destructive: true,
powerAssertVariableName: 'test',
lineSeparator: '\r\n'
targetMethods: {
oneArg: [
'ok',
'ng'
],
twoArgs: [
'equal',
'notEqual',
'strictEqual',
'notStrictEqual',
'deepEqual',
'notDeepEqual',
'projectSpecificEqual',
'notProjectSpecificEqual'
]
}
},
files: [
{
expand: true, // Enable dynamic expansion.
cwd: 'demo/', // Src matches are relative to this path.
src: ['**/*.js'], // Actual pattern(s) to match.
dest: 'espowered_demo/', // Destination path prefix.
ext: '.js' // Dest filepaths will have this extension.
}
]
},
},
})
Contributing
In lieu of a formal styleguide, take care to maintain the existing coding style. Add unit tests for any new or changed functionality. Lint and test your code using Grunt.
RELEASE HISTORY
See Release History
AUTHOR
LICENSE
Licensed under the MIT license.