“ng test”不能同时进行覆盖率报告和TeamCity报告
我正在尝试在TeamCity构建服务器上运行Angular CLI项目的单元测试.
如果我使用命令: ng test --single-run --code-coverage 然后,正如预期的那样,我得到了测试覆盖率报告,但是各个测试结果没有显示在TeamCity中. 如果我打开TeamCity报告: ng test --single-run --code-coverage --reporters teamcity 然后测试通过并且TeamCity报告完美地工作,但它无声地生成代码覆盖率报告.此行为在我的本地计算机上是可重现的,因此它与构建服务器的配置方式无关. 有这两个选项应该互相排斥的原因吗? 注意 – 这与Configuring code coverage report for Karma on TeamCity不同.如果报告在那里,那么TeamCity会正确显示它,但是如果我打开TeamCity报告标志,那么coverage文件夹就不存在了. 附加信息: > Angular-CLI版本1.0.0-rc.4(首次使用1.0.0-rc.1发现问题) 业力配置: // 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 }); }; 解决方法
我将其作为
issue on GitHub提出,Angular-CLI团队指出了解决方案:
ng test --single-run --code-coverage --reporters=teamcity,coverage-istanbul > –code-coverage选项仅在记者列表包含覆盖工具时才有效.如果没有覆盖率报告者,它将无声地失败.> –reporters开关替换默认的报告者列表,因此必须明确重新添加coverage-istanbul.>报道伊斯坦布尔的记者不会自己编写报告; –code-coverage开关仍然是必需的. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |