码迷,mamicode.com
首页 > Web开发 > 详细

[Webpack 2] Add Code Coverage to tests in a Webpack project

时间:2016-06-29 06:33:30      阅读:258      评论:0      收藏:0      [点我收藏+]

标签:

How much of your code runs during unit testing is an extremely valuable metric to track. Utilizing code the karma-coverage plugin and babel-plugin-__coverage__ plugin, we can get an accurate measure of how well we’re covering the files that we are testing.

 

Install:

npm i -D karam-coverage babel-plugin-__coverage__

 

 karma.config.js:
const webpackEnv = {test: true}
const webpackConfig = require(‘./webpack.config‘)(webpackEnv)
process.env.BABEL_ENV = ‘test‘ // so we load the correct babel plugins
const fileGlob = ‘src/js/**/*.test.js‘

module.exports = function setKarmaConfig(config) {
  config.set({
    basePath: ‘‘,
    frameworks: [‘mocha‘, ‘chai‘],
    files: [fileGlob],
    preprocessors: {
      [fileGlob]: [‘webpack‘]
    },
    webpack: webpackConfig,
    webpackMiddleware: {noInfo: true},
    reporters: [‘progress‘, ‘coverage],
    coverageReporter: {
      reporters: [
        {type: ‘lcov‘, dir: ‘coverage/‘, subdir: ‘.‘},
        {type: ‘json‘, dir: ‘coverage/‘, subdir: ‘.‘},
        {type: ‘text-summary‘},
      ],
    },
    port: 9876,
    colors: true,
    logLevel: config.LOG_INFO,
    autoWatch: false,
    browsers: [‘Chrome‘],
    singleRun: true,
    concurrency: Infinity
  })
}

 

.bablerc

{
  "presets": ["es2015-webpack", "stage-2"],
  "env": {
    "test": {
      "plugins": [
        ["__coverage__", {"ignore": "*.+(test|stub).*"}] // exclude .test & .stub files
      ]
    }
  }
}

 

package.json:

scripts: {
    "test": "karma start",
    "watch:test": "npm test -- --auto-watch --no-single-run",
    "validate": "npm-run-all --parallel validate-webpack:* lint test",
}

 

[Webpack 2] Add Code Coverage to tests in a Webpack project

标签:

原文地址:http://www.cnblogs.com/Answer1215/p/5625487.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!