istanbul-coverage-enforcer
v1.0.9
Published
A Nodejs package and cli tool to enforce code coverage
Downloads
150
Readme
istanbul-coverage-enforcer
A Nodejs package and cli tool to enforce global code coverage
Build status
npm status
Why?
Most of the coverage tools available do not provide an option to enforce the coverage and flag exception in case the coverage threshold is not met. This is one of the very frequently faced use cases I came across for most applications I work along with other team members. Due to struct deadlines we tend to miss out on tests and manually enforcing the test coverage to be maintained is not a scalable option.
This package solves the issue of manually maintaning the global code coverage above a given threshold
Installation
Use it with npm
as
npm install istanbul-coverage-enforcer
or with yarn as
yarn add istanbul-coverage-enforcer
Prerequisite
istanbul stable (0.4.5
or below) is needed to get the required interface of the coverage.json
file
Usage
You can use the istanbul-coverage-enforcer both as a node package and as a CLI tool
As a CLI tool:
These are the options available currently with the CLI tool
enforce --help
Usage: enforce [options]
Options:
-c, --coverage-path The path to coverage JSON file
-t, --threshold-path The path to the threshold JSON file
-h, --help output usage information
- Add a npm script in
package.json
to call the package with the path to the code-coverage file. By default this is atcoverage/coverage.json
"enforce-coverage": "enforce -c coverage/coverage.json -t coverage-threshold.json",
- Now you can run this script as part of your build to ensure that code coverage is maintained above threshold
npm run enforce-covergage
Output
As a node package
Create a
coverage-threshold.json
in the root of your project. Optionally this can be also passed as the second parameter to the functionIn your script import and call the
enforce
function as below:
const enforce = require('../index');
enforce('./examples/packages/coverage.json', './examples/packages/coverage-threshold.json');
Refer the examples folder for basic use case examples as node package and cli
Reference and Credits
istanbul-threshold-checker for getting the grunt work to compare and generate the result