karma-remap-istanbul正在生成源旁边的覆盖htmls

时间:2017-02-17 10:59:30

标签: javascript karma-runner aurelia istanbul karma-coverage

我正在尝试为我的Aurelia(+ webpack + TypeScript)网站设置单元测试。我的karma.conf.js看起来如下(类似于aurelia-navigation骨架中所做的):

"use strict";
const path = require('path');

module.exports = function (config) {
  config.set({
    basePath: __dirname,
    frameworks: ['jasmine'],
    exclude: [],

    files: [{
      pattern: 'spec-bundle.js',
      watched: false
    } ],

    preprocessors: {
      'spec-bundle.js': ['coverage', 'webpack', 'sourcemap']
    },

    webpack: require('../webpack.config'),

    coverageReporter: {
      reporters: [
        {
          type: 'json',
          subdir: '.',
          file: 'coverage-final.json'
        },
        {
          type: 'html',
          dir: path.join(__dirname, 'coverage/'),
          subdir: '.'
        }
      ]
    },

    remapIstanbulReporter: {
      src: path.join(__dirname, 'coverage/coverage-final.json'),
      reports: {
        html: path.join(__dirname, 'coverage/remapped/')
      }
      // ,
      // timeoutNotCreated: 1000,
      // timeoutNoMoreFiles: 1000
    },

    webpackServer: { noInfo: true },

    reporters: ['mocha', 'coverage', 'karma-remap-istanbul'],    

    port: 9876,
    colors: true,
    logLevel: config.LOG_INFO,
    autoWatch: false,
    browsers: [
      // 'Chrome',
      'SlimerJS'
    ],
    singleRun: true
  });


  console.log(config);
};

我的文件夹结构如下:

Website
|-src
|-test
| |-coverage
| |-unit 
| | |-*.spec.ts
| |-karma.conf.js
| |-spec.bundle.js //as given by aurelia-navigation skeleton
|-webpack.config.js

问题是karma-remap-istanbul正在将源htmls转储到源旁边,而不是输出test/coverage/remapped/中的所有内容。

我是否遗漏了任何配置?

1 个答案:

答案 0 :(得分:0)

尝试如下更新 remapIstanbulReporter 属性。

didDeselectRowAt

技巧是在放置路径的同时提供'./',它会将相对路径w.r.t移至文件夹结构中文件的位置。

当您将路径指定为'folder / folderA / folderB'时,它将采用绝对路径。