Ali*_*een 5 teamcity istanbul karma-jasmine karma-coverage angular-cli
我正在尝试在TeamCity构建服务器上运行Angular CLI项目的单元测试.
如果我使用命令:
ng test --single-run --code-coverage
Run Code Online (Sandbox Code Playgroud)
然后,正如预期的那样,我得到了测试覆盖率报告,但是各个测试结果没有显示在TeamCity中.
如果我打开TeamCity报告:
ng test --single-run --code-coverage --reporters teamcity
Run Code Online (Sandbox Code Playgroud)
然后测试通过并且TeamCity报告完美地工作,但它无声地生成代码覆盖率报告.此行为在我的本地计算机上是可重现的,因此它与构建服务器的配置方式无关.
有这两个选项应该互相排斥的原因吗?
注意 - 这与在TeamCity上为Karma配置代码覆盖率报告不同.如果报告在那里,那么TeamCity会正确显示它,但如果我打开TeamCity报告标志,那么coverage文件夹就不存在了.
附加信息:
业力配置:
// Karma configuration file, see link for more information
// https://karma-runner.github.io/0.13/config/configuration-file.html
module.exports = function (config) {
config.set({
basePath: '',
frameworks: ['jasmine', '@angular/cli'],
plugins: [
require('karma-jasmine'),
require('karma-chrome-launcher'),
require('karma-jasmine-html-reporter'),
require('karma-coverage-istanbul-reporter'),
require('@angular/cli/plugins/karma'),
require('karma-teamcity-reporter')
],
client:{
clearContext: false // leave Jasmine Spec Runner output visible in browser
},
files: [
{ pattern: './src/test.ts', 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
});
};
Run Code Online (Sandbox Code Playgroud)
我在GitHub上提出这个问题, Angular-CLI团队指出了解决方案:
ng test --single-run --code-coverage --reporters=teamcity,coverage-istanbul
Run Code Online (Sandbox Code Playgroud)
--code-coverage选项仅在记者列表包含覆盖工具时有效.如果没有覆盖率报告者,它将无声地失败.--reporters开关取代默认的记者名单,因此coverage-istanbul必须显式重新添加.coverage-istanbul记者不产生自身的报告; 该--code-coverage开关仍然需要.| 归档时间: |
|
| 查看次数: |
2474 次 |
| 最近记录: |