A seamless JavaScript code coverage library.
Project home page
Blanket_js on Twitter for updates and news.
Notice Mar 9, 2013 - The Blanket repo has moved from Migrii/blanket to alex-seville/blanket. Local forks need to be updated.
- Getting Started
- Philosophy
- Mechanism
- Grunt-Blanket
- Compatibility & Features List
- Roll Your Own
- Development
- Contact
- Contributors
- Roadmap
- Revision History
NOTE: Blanket.js will throw XHR cross domain errors if run with the file:// protocol. See Special Features Guide for more details and workarounds.
Please see the following guides for using Blanket.js:
Browser
- Getting Started (Basic QUnit usage)
- Intermediate (Other test runners, global options)
- Advanced (writing your own reporters/adapters)
- Special Features Guide
Node
- Getting Started (basic mocha setup)
- Intermediate (mocha testrunner, travis-ci reporter)
Blanket.js is a code coverage tool for javascript that aims to be:
- Easy to install
- Easy to use
- Easy to understand
Blanket.js can be run seamlessly or can be customized for your needs.
JavaScript code coverage compliments your existing JavaScript tests by adding code coverage statistics (which lines of your source code are covered by your tests).
Blanket works in a 3 step process:
- Loading your source files using a modified RequireJS/Require script
- Parsing the code using Esprima and node-falafel, and instrumenting the file by adding code tracking lines.
- Connecting to hooks in the test runner to output the coverage details after the tests have completed.
A Grunt plugin has been created to allow you to use Blanket like a "traditional" code coverage tool (creating instrumented copies of physical files, as opposed to live-instrumenting). The plugin runs as a standlone project and can be found here.
See the Compatiblity and Feature List including links to working examples.
git clone [email protected]:alex-seville/blanket.git
npm install
- Add your custom build details to the grunt.js file under
concat
grunt buildit
A minified and unminfied copy of the source can be created (see the min
task).
All development takes place on the upcoming version branch (currently 1.1.2).
Your pull request must pass all tests (run npm test
to be sure) and respect all existing coverage thresholds
Feel free to add questions to the Issue tracker, or send them to @blanket_js.
Thanks to the following people:
- dervalp
- morkai
- msaglietto
- adambiggs
- ashwinr
- provegard
- orient-man
- tmrudick
- wpreul
- xzyfer
- hasankhan
- mohamedmansour
- strife25
- flrent
And thanks also to: RequireJS, Esprima, node-falafel, Mocha, Qunit.
Apr 15-13 - 1.1.2
Instrumentation cacheing, and LCOV reporter, and passing options to custom reporters.
Apr 2-13 - 1.1.1
CommonJS support, based on Browserify. Disable require loader when coverage is disabled (in QUnit).
Mar 22-13 - 1.1.0 Custom variable data attribute to use whatever variable you want for coverage tracking.
Mar 22-13 - 1.0.9 Blanket is not run on require in node now. Update to component version for bower. Branch tracking reporting fix. Preserve filenames in Node.
Mar 14-13 - 1.0.8 Improvement to branch tracking
Mar 11-13 - 1.0.7 Moving repo to alex-seville/blanket.
Feb 12-13 - 1.0.6 Added debug setting to track program flow. Minor fixes on both browser and node side.
Feb 8-13 - 1.0.5
Node version will avoid instrumenting anything not in the current directory using onlyCwd: true
in the package.json file.
Feb 7-13 - 1.0.4 Node version can use the same input attributes as client side version, branchTracking reporting for client, use string, regex or array as filter for node, loading issue fixes for requirejs+blanket.
Jan 23-13 - 1.0.3 Dependencies fixed for node. Various other fixes.
Jan 13-13 - 1.0.2 Branch tracking, Jasmine/RequireJS compatibility fixes, data-cover-never, data-cover-timeout attributes added, fixed bug in mocha adapter, fixed instrumentation of labelled statements, local uploader to deal with CORS issues.
Dec 31-12 - 1.0.1 User guides, minification fixes, coffeescript/custom loader support for browser & node, replaced getters/setters with blanket.options.
Dec 14-12 - 1.0.0 Added to Bower, fixed relative paths issues, added noConflict, refactored core code, added Twitter Bootstrap example.
Dec-8-12 - 0.9.9 Moved Makefile into grunt and reorganized files. Fixed instrumenting of comments in node.
Dec-3-12 - 0.9.8 Fixes to instrumentation, fix for escaped characters in node. Added adapters and Jasmine example.
Nov-26-12 - 0.9.7 Custom reporters. Better organization of tests.
Nov-24-12 - 0.9.6 Better line counts, more tests, normalizing slashes for windows, require loader uses module._compile to properly pass the exports, added Makefile for CI, various other fixes.
Nov-19-12 - 0.9.4 Major refactoring, QUnit tests run with phantomjs, both node and browser tests are covered by blanket on travis-ci. Compatibility with existing requirejs instance.
Nov-8-12 - 0.9.2 Bug fixes to instrumentation and node require loader.
Nov-4-12 - 0.9.1 Works seamlessly with mocha (in node) and uses built in mocha reporters for coverage.
Oct-29-12 - 0.9.0 Initial release of blanket.js. Works with qunit, but coverage output is not complete.
Copyright (c) 2012 Alex-Seville
Licensed under the MIT license.