【问题标题】:Angular karma code coverage report folder not generated未生成角业力代码覆盖率报告文件夹
【发布时间】:2019-08-02 08:03:18
【问题描述】:

当我运行ng test --code-coverage 时,覆盖率报告有时没有生成,有时它正在生成,所以我在做测试套件后无法验证覆盖率声明。

我的 Karma 配置

// Karma configuration file, see link for more information
// https://karma-runner.github.io/1.0/config/configuration-file.html

module.exports = function (config) {
  config.set({
    basePath: '',
    frameworks: ['jasmine', '@angular-devkit/build-angular'],
    plugins: [
      require('karma-jasmine'),
      require('karma-chrome-launcher'),
      require('karma-jasmine-html-reporter'),
      require('karma-coverage-istanbul-reporter'),
      require('@angular-devkit/build-angular/plugins/karma')
    ],
    client: {
      clearContext: false // leave Jasmine Spec Runner output visible in browser
    },
    coverageIstanbulReporter: {
      dir: require('path').join(__dirname, '../coverage'),
      reports: ['html', 'lcovonly'],
      fixWebpackSourcePaths: true
    },
    reporters: ['progress', 'kjhtml'],
    port: 9876,
    colors: true,
    logLevel: config.LOG_INFO,
    autoWatch: true,
    browsers: ['Chrome'],
    singleRun: false
  });
};

【问题讨论】:

    标签: angular unit-testing karma-jasmine code-coverage


    【解决方案1】:

    在我的情况下,一切似乎都是正确的,但控制台上没有生成任何覆盖文件或消息。

    解决问题的方法是编辑 angular.json,添加以下键:

    projects.ClientApp.test.options.codeCoverage = true;
    

    【讨论】:

      【解决方案2】:

      没有生成代码覆盖率的原因是,有一些损坏的单元测试会停止生成代码覆盖率文件夹。尽管它会生成一些时间,但这也必须比平时花费很多时间。按照以下步骤,为了识别和修复单元测试,代码覆盖文件将每次生成-

      1. 使用npm test 运行测试。
      2. 打开浏览器并检查测试,不应该有任何损坏或失败的测试用例。
      3. 它不应该给出任何控制台错误(在控制台上验证并修复它。)
      4. 验证所有单元测试是否正在运行并成功通过。有时它会显示通过的单元测试,但它会给出一些弹出错误或控制台错误,因此这些测试会阻止单元测试代码覆盖率的生成。

      修复所有测试,它应该每次都生成单元测试代码覆盖文件夹。

      【讨论】:

      • 不,但是测试套件都是绿色的。没有错误或中断
      • 但我没有检查控制台错误,将再次检查,谢谢,
      • 只需检查控制台,或者如果您收到错误警报,然后解决所有问题。我在修复它们时遇到了类似的问题,我花了很多时间来确定确切的问题。
      • 另外,如果它确实有帮助,那么别忘了给答案投票。
      • 尝试以某种方式解决该问题,您可以尝试使用 --sourceMap=false 选项,这将帮助您详细了解错误。
      【解决方案3】:

      通过以下命令生成新的代码覆盖率文件夹

      node --max_old_space_size=4096 ./node_modules/karma/bin/karma start ./test-config/karma.conf.js --coverage
      

      【讨论】:

        【解决方案4】:

        在您的 Karma.conf.js 文件中添加以下配置

        module.exports = function(config) {
          config.set({
           ...
           coverageReporter: {
              dir: require('path').join(__dirname, 'dist/coverage/app-coverage'),
              subdir: '.',
              reporters: [
                { type: 'html' },
                { type: 'text-summary' },
                { type: 'cobertura' }
              ]
            }
           }
        

        然后运行:

        ng test  --code-coverage=true
        

        它将生成精确的代码覆盖率报告,现在进入目录dist/coverage/app-coverage并在浏览器中打开index.html文件。它将提供单个文件的代码覆盖率以及需要覆盖的代码部分。

        【讨论】:

          猜你喜欢
          • 2016-03-21
          • 2015-05-22
          • 1970-01-01
          • 2014-03-21
          • 1970-01-01
          • 2021-06-26
          • 2011-03-09
          • 2019-01-29
          • 1970-01-01
          相关资源
          最近更新 更多