Karma 代码覆盖率 - 总是 100%?

Posted

技术标签:

【中文标题】Karma 代码覆盖率 - 总是 100%?【英文标题】:Karma Code Coverage - Always 100%? 【发布时间】:2015-09-17 04:41:38 【问题描述】:

早安,

我遇到了一个似乎无法解决的奇怪问题。我写出了我的 Karma 测试并正确执行,但是当我尝试连接 Karma 的代码覆盖率时,无论如何它只会吐出 100%。

我查看了这里提出的其他问题,但似乎都没有解决我的问题。任何帮助将不胜感激。

使用:

"karma": "~0.12.37",
"karma-babel-preprocessor": "^5.2.1",
"karma-browserify": "^4.2.1",
"karma-coverage": "^0.4.2",
"karma-jasmine": "~0.3.5",
"karma-phantomjs-launcher": "^0.2.0",

这是我的 karma.conf.js

module.exports = function (config) 
  config.set(
    basePath: '',

    frameworks: ['browserify', 'jasmine'],

    files: [
        'bower_components/jquery/dist/jquery.js',
        'bower_components/angular/angular.js',
        'bower_components/angular-animate/angular-animate.js',
        'bower_components/angular-cookies/angular-cookies.js',
        'bower_components/angular-mocks/angular-mocks.js',
        'bower_components/angular-resource/angular-resource.js',
        'bower_components/angular-sanitize/angular-sanitize.js',
        'bower_components/angular-touch/angular-touch.js',
        'bower_components/angular-ui-router/release/angular-ui-router.js'
        'src/*.html',
        'src/**/*.html',
        'src/app/index.js',
        'src/app/**/*.js'
    ],

    exclude: [],

    preprocessors: 
        'src/app/index.js': ['browserify', 'coverage'],
        'src/app/**/*.js': ['browserify', 'coverage']
    ,

    browserify: 
        debug: true,
        transform: ['babelify', 'stringify']
    ,

    reporters: ['progress', 'coverage'],

    port: 9876,

    colors: true,

    autoWatch: true,

    browsers: ['PhantomJS'],

    singleRun: false
  );
;

我的文件结构是:

src
  app
    login
      login.controller.js
      login.controller.spec.js
      login.html
    index.js
karma.conf.js

谢谢!

【问题讨论】:

同时使用 karma-browserifykarma-coverage 预处理器导致。查看***.com/a/28237582/2943490 以了解同时使用 browserify 和 istanbul(业力覆盖使用的内容)的工作配置。 【参考方案1】:

您是否尝试过使用browserify-istanbul 转换?

module.exports = function(config) 
    config.set(
         // ...
         browserify: 
             transform: ['browserify-istanbul', ...]
         
    );
;

您需要“检测”您的代码以收集覆盖率指标。所以你应该告诉browserify 在返回带有require 的模块之前应用检测。

【讨论】:

以上是关于Karma 代码覆盖率 - 总是 100%?的主要内容,如果未能解决你的问题,请参考以下文章

Karma,覆盖率报告结合 webpack

获取预编译源代码的 Karma 代码覆盖率

在 TeamCity 上为 Karma 配置代码覆盖率报告

Karma 代码覆盖率未在 Sonarqube 中显示

使用 karma-jasmine 和 istanbul 的 Typescript 代码覆盖率

使用 karma-jasmine 和 istanbul 的 Typescript 代码覆盖率