Skip to content

cypress-io/code-coverage

Folders and files

NameName
Last commit message
Last commit date

Latest commit

8cf33f4 · Jun 4, 2019

History

20 Commits
May 20, 2019
May 20, 2019
May 15, 2019
May 15, 2019
May 15, 2019
May 15, 2019
Jun 4, 2019
May 15, 2019
Jun 4, 2019
Jun 4, 2019
May 15, 2019
May 17, 2019
Jun 4, 2019
May 20, 2019

Repository files navigation

@cypress/code-coverage renovate-app badge CircleCI

Saves the code coverage collected during Cypress tests

Install

npm install -D @cypress/code-coverage

and its peer dependencies

npm install -D nyc istanbul-lib-coverage cypress

Add to your cypress/support/index.js file

import '@cypress/code-coverage/support'

Register tasks in your cypress/plugins/index.js file

module.exports = (on, config) => {
  on('task', require('@cypress/code-coverage/task'))
}

If your application is loaded Istanbul-instrumented source code, then the coverage information will be automatically saved into .nyc_output folder and a report will be generated after the tests finish (even in the interactive mode). Find the HTML report in the coverage folder.

Coverage report

That should be it!

Instrument unit tests

If you test your application code directly from specs you might want to instrument them and combine unit test code coverage with any end-to-end code coverage (from iframe). You can easily instrument spec files using babel-plugin-istanbul for example.

Install the plugin

npm i -D babel-plugin-istanbul

Set your .babelrc file

{
  "plugins": ["istanbul"]
}

Put the following in cypress/plugins/index.js file to use .babelrc file

module.exports = (on, config) => {
  on('task', require('@cypress/code-coverage/task'))
  on('file:preprocessor', require('@cypress/code-coverage/use-babelrc'))
}

Now the code coverage from spec files will be combined with end-to-end coverage.

Examples

Debugging

Run tests with DEBUG=code-coverage environment variable to see log messages

License

This project is licensed under the terms of the MIT license.