获取预编译源代码的 Karma 代码覆盖率
Getting Karma code coverage for pre-transpilation source code
我使用 Karma 进行 运行 测试,使用 webpack 打包文件,使用 babel 进行 es6 -> es5 转换。我已经得到了测试 运行ning 和正在生成的代码覆盖率,但代码覆盖率数字是针对转译后的源文件的。有没有办法获取原始源文件的代码覆盖率?
我尝试使用 sourcemap
预处理器,但它似乎没有做任何事情。我需要将它添加到 webpack 配置的某个地方吗?
karma.conf.js
config.set({
browsers: ['Chrome'], //run in Chrome
files: [
'src/**/*-test.js'
],
frameworks: ['mocha'], //use the mocha test framework
plugins: [
'karma-chrome-launcher',
'karma-mocha',
'karma-sourcemap-loader',
'karma-webpack',
'karma-coverage',
],
preprocessors: {
'src/**/*-test.js': ['webpack']
},
reporters: ['dots', 'coverage'], //report results in this format
coverageReporter: {
reporters: [{
type: 'text-summary',
}, {
type: 'html',
dir: 'build/reports/coverage'
}]
},
singleRun: true, //just run once by default
webpack: {
node: {
fs: 'empty'
},
// Instrument code that isn't test or vendor code.
module: {
loaders: [{
test: /\.js?$/,
include: path.join(__dirname, 'src/js'),
loader: 'babel?stage=0'
}],
postLoaders: [{
test: /\.js$/,
exclude: /(test|node_modules)\//,
loader: 'istanbul-instrumenter'
}]
}
},
webpackMiddleware: {
noInfo: true //please don't spam the console when running in karma!
}
});
以下配置工作正常:
karma.conf.js
var path = require('path');
module.exports = function(config) {
config.set({
browsers: [ 'Chrome' ], //run in Chrome
files: [
'src/**/*-test.js'
],
frameworks: [ 'mocha' ], //use the mocha test framework
preprocessors: {
'src/**/*-test.js': [ 'webpack' ]
},
reporters: [ 'dots', 'coverage' ], //report results in this format
coverageReporter: {
reporters: [
{
type: 'text-summary'
},
{
type: 'html',
dir: 'build/reports/coverage'
}
]
},
singleRun: true, //just run once by default
webpack: {
node : {
fs: 'empty'
},
// Instrument code that isn't test or vendor code.
module: {
preLoaders: [
{ test: /\.js$/, loader: 'isparta', include: path.join(__dirname, 'src/js') }
],
loaders: [
{
test: /\.js$/,
include: path.join(__dirname, 'src/js'),
loader: 'babel?stage=0'
}
]
}
},
webpackMiddleware: {
noInfo: true //please don't spam the console when running in karma!
}
});
};
package.json
{
"devDependencies": {
"babel-core": "^5.8.22",
"babel-loader": "^5.3.2",
"chai": "^3.2.0",
"isparta-loader": "^0.2.0",
"karma": "^0.13.9",
"karma-chrome-launcher": "^0.2.0",
"karma-coverage": "^0.5.0",
"karma-mocha": "^0.2.0",
"karma-webpack": "^1.7.0",
"mocha": "^2.2.5",
"webpack": "^1.11.0"
}
}
我使用 Karma 进行 运行 测试,使用 webpack 打包文件,使用 babel 进行 es6 -> es5 转换。我已经得到了测试 运行ning 和正在生成的代码覆盖率,但代码覆盖率数字是针对转译后的源文件的。有没有办法获取原始源文件的代码覆盖率?
我尝试使用 sourcemap
预处理器,但它似乎没有做任何事情。我需要将它添加到 webpack 配置的某个地方吗?
karma.conf.js
config.set({
browsers: ['Chrome'], //run in Chrome
files: [
'src/**/*-test.js'
],
frameworks: ['mocha'], //use the mocha test framework
plugins: [
'karma-chrome-launcher',
'karma-mocha',
'karma-sourcemap-loader',
'karma-webpack',
'karma-coverage',
],
preprocessors: {
'src/**/*-test.js': ['webpack']
},
reporters: ['dots', 'coverage'], //report results in this format
coverageReporter: {
reporters: [{
type: 'text-summary',
}, {
type: 'html',
dir: 'build/reports/coverage'
}]
},
singleRun: true, //just run once by default
webpack: {
node: {
fs: 'empty'
},
// Instrument code that isn't test or vendor code.
module: {
loaders: [{
test: /\.js?$/,
include: path.join(__dirname, 'src/js'),
loader: 'babel?stage=0'
}],
postLoaders: [{
test: /\.js$/,
exclude: /(test|node_modules)\//,
loader: 'istanbul-instrumenter'
}]
}
},
webpackMiddleware: {
noInfo: true //please don't spam the console when running in karma!
}
});
以下配置工作正常:
karma.conf.js
var path = require('path');
module.exports = function(config) {
config.set({
browsers: [ 'Chrome' ], //run in Chrome
files: [
'src/**/*-test.js'
],
frameworks: [ 'mocha' ], //use the mocha test framework
preprocessors: {
'src/**/*-test.js': [ 'webpack' ]
},
reporters: [ 'dots', 'coverage' ], //report results in this format
coverageReporter: {
reporters: [
{
type: 'text-summary'
},
{
type: 'html',
dir: 'build/reports/coverage'
}
]
},
singleRun: true, //just run once by default
webpack: {
node : {
fs: 'empty'
},
// Instrument code that isn't test or vendor code.
module: {
preLoaders: [
{ test: /\.js$/, loader: 'isparta', include: path.join(__dirname, 'src/js') }
],
loaders: [
{
test: /\.js$/,
include: path.join(__dirname, 'src/js'),
loader: 'babel?stage=0'
}
]
}
},
webpackMiddleware: {
noInfo: true //please don't spam the console when running in karma!
}
});
};
package.json
{
"devDependencies": {
"babel-core": "^5.8.22",
"babel-loader": "^5.3.2",
"chai": "^3.2.0",
"isparta-loader": "^0.2.0",
"karma": "^0.13.9",
"karma-chrome-launcher": "^0.2.0",
"karma-coverage": "^0.5.0",
"karma-mocha": "^0.2.0",
"karma-webpack": "^1.7.0",
"mocha": "^2.2.5",
"webpack": "^1.11.0"
}
}