Karma-Coverage和Istanbul HTML报告未输出到预期目录

时间:2015-09-03 09:44:54

标签: angularjs node.js unit-testing karma-jasmine karma-coverage

我在让伊斯坦布尔将其HTML报告输出到我的Karma配置中指定的目录时遇到问题。它当前在正确的目录(reports/coverage)中输出主index.html,但详细的html子页面输出到与源文件(www/js/...)相同的目录。这与herehere描述的问题相同,但在尝试建议的解决方案后问题仍然存在。

这是我的业力配置文件的内容:

basePath: './',

frameworks: ['jasmine'],

files: [
  'www/lib/angular/angular.js',
  'www/js/*.js',
  'www/js/services/*.js',
  'www/js/controllers/*.js',
  'www/lib/angular-mocks/angular-mocks.js',
  'tests/**/*test.js',
  'tests/test-data/*.json'
],

plugins: [
  'karma-jasmine',
  'karma-coverage',
  'karma-phantomjs-launcher',
  'karma-ng-json2js-preprocessor'
],

preprocessors: {
  'www/js/**/*.js': ['coverage'],
  'tests/**/*.json':         ['ng-json2js']
},

ngJson2JsPreprocessor: {
  stripPrefix: 'tests/test-data/',
  prependPrefix: 'served/'
},

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

port: 9876,
colors: true,
logLevel: config.LOG_INFO,
autoWatch: true,
browsers: ['PhantomJS'],
singleRun: true,

coverageReporter: {
  // Common output directory
  dir: 'coverage',
  reporters: [
    { type: 'text-summary'},
    { type: 'html', subdir:'report-html' }
  ]
}

有关如何解决此问题以便将所有覆盖文件放入reports/coverage目录的建议将非常感激。感谢。

1 个答案:

答案 0 :(得分:2)

我自己也在努力解决这个问题,并且发现我必须在coverageReporter配置的记者部分更明确地指定每个目录和子目录。

coverageReporter: {
  reporters: [
    { type: 'text-summary', dir: 'coverage/' },
    { type: 'html', dir: 'coverage/', subdir: 'report-html' }
  ]
}

我无法解释为什么这种组合最终对我有用,但经过多次排列之后,这就是我最终的结果。