使用gulp istanbul的ES6的代码覆盖率

时间:2017-12-26 21:36:48

标签: javascript node.js code-coverage istanbul gulp-mocha

我试图为我的具有mocha测试的节点js es6应用程序生成伊斯坦布尔覆盖率报告。我使用isparta来测试代码,也使用babel从ES6转换到ES5,但遗憾的是没有任何工作。是否有人使用gulp istanbul成功生成代码覆盖率报告。当我在非ES6代码覆盖率报告中从命令行运行nyc时,报告很快(我在非ES6样式上编写了一些单元测试)。请找到以下代码。

gulp.task('coverage',function(cb){
    return gulp.src(['./server/controllers/*.js','./server/services/*.js'])
        .pipe(istanbul({
            includeUntested:true,
            instrument: Instrumenter,
        excludes:[['*.spec.js', '*.watcherSpec.js','*.intspec.js',]]}))
        .pipe(babel({
            plugins:[["transform-es2015-arrow-functions",{ "spec": true }]]
        }))
        .pipe(istanbul.hookRequire()) //force 'require' to return covered files
})

gulp.task('api-tests', ['coverage'], function (cb) {
    gulp.src(['./server/**/*.intspec.js'])
        .pipe(mocha({
            harmony: true,
            timeout: '10000',
            reporter: 'spec',
            excludes: ['*.spec.js', '*.watcherSpec.js'],
            env: {
                'NODE_ENV': 'integration-testing',
                'hostedAddress': hostedAddress
            }
        }))
        .pipe(istanbul.writeReports({
            dir: './coverage',
            reporters: [ 'html' ],
            reportOpts: { dir: './coverage'}
        }))
        .on('end', cb);
});

0 个答案:

没有答案