在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
});
};
答案 0 :(得分:1)
我认为你在使用coverage时也需要使用html报告器:
reporters: config.angularCli && config.angularCli.codeCoverage
? ['progress', 'kjhtml', 'coverage-istanbul']
: ['progress', 'kjhtml'],
您基本上可以根据-cc
标志使用不同的记者。
请注意,“进度”报告器是基于控制台的运行报告。