我通过伊斯坦布尔检查TypeScript文件中的测试覆盖率。我需要通过karma-coverage设置测试阈值。伊斯坦布尔的报告与karma-coverage报告(我使用Angular-cli)不匹配,因为karma-coverage检查JavaScript文件中的测试覆盖率而不是TypeScript。我使用了其他插件,如karma-threshold-reporter,istanbul-threshold-checker但结果相同。我该如何解决?
report generate for typeScript files
module.exports = function (config) {
config.set({
basePath: '',
frameworks: ['jasmine', 'angular-cli'],
plugins: [
require('karma-jasmine'),
require('karma-chrome-launcher'),
require('karma-remap-istanbul'),
require('karma-coverage'),
require('angular-cli/plugins/karma')
],
files: [
{ pattern: './src/test.ts', watched: false }
],
preprocessors: {
'./src/test.ts': ['angular-cli']
},
remapIstanbulReporter: {
reports: {
html: 'coverage',
lcovonly: './coverage/coverage.lcov'
}
},
coverageReporter: {
dir: 'coverage/',
reporters: [
{type: 'text-summary'},
{type: 'html'}
],
check: {
global: {
statements: 70,
branches: 70,
functions: 70,
lines: 50
}
}
},
angularCli: {
config: './angular-cli.json',
environment: 'dev'
},
reporters: ['progress', 'karma-remap-istanbul', 'coverage'],
port: 9876,
colors: true,
logLevel: config.LOG_INFO,
autoWatch: true,
browsers: ['Chrome'],
singleRun: false
});
};
答案 0 :(得分:2)
plugin: ['karma-remap-istanbul', 'karma-istanbul-threshold'],
coverageReporter: {
type: 'in-memory',
},
remapCoverageReporter: {
'text-summary': null,
json: './coverage/coverage-final.json',
html: './coverage/html-ts'
},
istanbulThresholdReporter: {
src: './coverage/coverage-final.json',
reporters: ['text'],
thresholds: {
global: {
statements: 90,
branches: 90,
lines: 90,
functions: 90,
}
},
},
此配置对我有用。