• [Webpack 2] Ensure all source files are included in test coverage reports with Webpack


    If you’re only instrumenting the files in your project that are under test then your code coverage report will be misleading and it will be difficult for you to track or enforce improvements to application coverage over time. In this lesson we’ll learn how to ensure all source files are included in coverage reports and how to enforce a specific threshold so you can work toward improving application code coverage.

    Install:

    npm i -D istanbul

    Include all the src code not only test code:

    const webpackEnv = {test: true}
    const webpackConfig = require('./webpack.config')(webpackEnv)
    process.env.BABEL_ENV = 'test' // so we load the correct babel plugins
    const testGlob = 'src/js/**/*.test.js'
    const srcGlob = 'src/js/**/*!(test|stub).js'
    
    module.exports = function setKarmaConfig(config) {
      config.set({
        basePath: '',
        frameworks: ['mocha', 'chai'],
        files: [testGlob, srcGlob],
        preprocessors: {
          [testGlob]: ['webpack'],
          [srcGlob]: ['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
      })
    }

    Use istanbul cli to check code coverage not below cetain number:

    "check-coverage": "istanbul check-coverage --statements 23 --branches 5 --functions 9 --lines 24",

    Add to validator:

    "validate": "npm-run-all --parallel validate-webpack:* lint test --serial check-coverage",

    Because it checkout coverage should run after test,  so add '--serial' flag

  • 相关阅读:
    mysql定时器,定时查询数据库,把查询结果插入到一张表中 阿星小栈
    如何写mysql的定时任务 阿星小栈
    利用mysql游标循环结果集 阿星小栈
    页面可见生Page Visibility
    css之z-index
    css之页面三列布局之左右两边宽度固定,中间自适应
    css之页面两列布局
    jquery源码学习之extend
    jquery源码学习之queue方法
    HTTP状态码详解
  • 原文地址:https://www.cnblogs.com/Answer1215/p/5625494.html
Copyright © 2020-2023  润新知