Angular CLI运行测试报告和代码覆盖率报告

时间:2017-05-03 12:15:56

标签: angular karma-runner

在Angular CLI中,是否可以开始使用Karma进行测试并同时返回代码覆盖率?

解释

正在运行ng test启动Chrome并运行测试,因此我可以在Chrome上看到结果。

运行ng test -cc启动Chrome,运行测试,不显示显示测试结果,并在coverage目录中生成代码覆盖率报告。

两者都有可能吗?所以我可以受益于" live"测试编码经验和生成的代码报告以及Chrome中显示的测试结果。

当前karma.conf.js

module.exports = function (config) {
  config.set({
    basePath: '',
    frameworks: ['jasmine', '@angular/cli', 'intl-shim'],
    plugins: [
      require('karma-jasmine'),
      require('karma-chrome-launcher'),
      require('karma-phantomjs-launcher'),
      require('karma-jasmine-html-reporter'),
      require('karma-mocha-reporter'),
      require('karma-coverage-istanbul-reporter'),
      require('@angular/cli/plugins/karma'),
      require('karma-intl-shim')
    ],
    client:{
      clearContext: false // leave Jasmine Spec Runner output visible in browser
    },
    files: [
      { pattern: './src/test.ts', watched: false },
      { pattern: './node_modules/intl/locale-data/jsonp/en-US.js', watched: false }
    ],
    preprocessors: {
      './src/test.ts': ['@angular/cli']
    },
    mime: {
      'text/x-typescript': ['ts','tsx']
    },
    coverageIstanbulReporter: {
      reports: [ 'html', 'lcovonly' ],
      fixWebpackSourcePaths: true
    },
    angularCli: {
      environment: 'dev'
    },
    reporters: config.angularCli && config.angularCli.codeCoverage
              ? ['progress', 'coverage-istanbul']
              : ['progress', 'kjhtml'],
    port: 9876,
    colors: true,
    logLevel: config.LOG_INFO,
    autoWatch: true,
    browsers: ['Chrome'],
    singleRun: false
  });
};

1 个答案:

答案 0 :(得分:1)

我认为你在使用coverage时也需要使用html报告器:

 reporters: config.angularCli && config.angularCli.codeCoverage
          ? ['progress', 'kjhtml', 'coverage-istanbul']
          : ['progress', 'kjhtml'],

您基本上可以根据-cc标志使用不同的记者。

请注意,“进度”报告器是基于控制台的运行报告。