Karma + Browserify + Jasmine + 伊斯坦布尔 + React 覆盖

Posted

技术标签:

【中文标题】Karma + Browserify + Jasmine + 伊斯坦布尔 + React 覆盖【英文标题】:Karma + Browserify + Jasmine + Istanbul + React coverage 【发布时间】:2016-01-22 00:21:45 【问题描述】:

我正在尝试获取我的测试的覆盖率报告,但所有文件的覆盖率输出总是在一行中,显示文件路径的要求。比如……

但是测试运行良好。这是一个反应项目,所以我必须包含一些额外的文件路径和预处理器才能运行测试。

我不确定我的 karma 配置是否有问题?这就是我目前的配置...

/* global module */
module.exports = function (config) 
    'use strict';
    config.set(
        autoWatch: true,
        singleRun: true,

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

        files: [
            'node_modules/karma-babel-preprocessor/node_modules/babel-core/browser-polyfill.js',
            'node_modules/react/react.js',
            'src/**/*.jsx',
            'src/**/!(*spec).js'
        ],

        browsers: ['PhantomJS'],

        preprocessors: 
            'node_modules/react/react.js': ['browserify', 'sourcemap'],
            'src/**/*.jsx': ['browserify', 'sourcemap', 'coverage'],
            'src/**/!(*spec).js': ['browserify', 'sourcemap', 'coverage'],
        ,

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

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

        coverageReporter: 
            instrumenters: isparta: require('isparta'),
            instrumenter: 
                'src/**/*.js': 'isparta',
                'src/**/*.jsx': 'isparta'

            ,
            reporters: [
                
                    type: 'text-summary',
                    subdir: normalizationBrowserName
                ,
                
                    type: 'lcov',
                    subdir: normalizationBrowserName
                ,
                
                    type: 'html',
                    dir: 'coverage/',
                    subdir: normalizationBrowserName
                
            ]
        

    );

    function normalizationBrowserName(browser) 
        return browser.toLowerCase().split(/[ /-]/)[0];
    

;

更新: 我也使用了 commonjs 转换,并且能够让事情更好地工作,但测试无法运行,并且覆盖范围是转换后的代码。

【问题讨论】:

【参考方案1】:

确保包含您的所有源代码以进行覆盖。例如,我有以下 karma.conf.js:(检查预处理器部分)

// Karma configuration
// Generated on Mon Sep 07 2015 23:22:13 GMT-0400 (Eastern Daylight Time)

module.exports = function(config) 

    var SourceCode = [
        'app/app.js',
        'app/Modules/*.js',                     // Basic Path Files (Modules for Source, UnitTests to keep test files separate)
        'app/Modules/**/_*.init.js',            // Declarative functions needed for next line - Initialization Code
        'app/Modules/**/*.js',
        'app/UnitTests/**/*.mock.js',           // Mock Declarations for Tests
        'app/UnitTests/**/*.test.js'
    ];

    var Libraries = [
        'app/bower_components/angular/angular.js',
        'app/bower_components/angular-animate/angular-animate.js',
        'app/bower_components/angular-aria/angular-aria.js',
        'app/bower_components/angular-route/angular-route.js',
        'app/bower_components/firebase/firebase.js',
        ...
// Testing
        'app/bower_components/angular-mocks/angular-mocks.js',
        'app/bower_components/angular-material/angular-material-mocks.js',
        'app/bower_components/mockfirebase/browser/mockfirebase.js',
        'node_modules/sinon/pkg/sinon.js',
    ];

    config.set(
        // base path that will be used to resolve all patterns (eg. files, exclude)
        basePath: '',


        // frameworks to use
        // available frameworks: https://npmjs.org/browse/keyword/karma-adapter
        frameworks: ['mocha', 'chai'],      // 


        // list of files / patterns to load in the browser
        files: Libraries.concat(SourceCode),


        // list of files to exclude
        exclude: [
        ],


        // preprocess matching files before serving them to the browser
        // available preprocessors: https://npmjs.org/browse/keyword/karma-preprocessor
        preprocessors: 
            'app/Modules/**/*.js': ['coverage']          // Ensure all files are in Code Coverage
        ,

        // test results reporter to use
        // possible values: 'dots', 'progress'
        // available reporters: https://npmjs.org/browse/keyword/karma-reporter
        reporters: ['progress', 'coverage'],    

        coverageReporter: 
            type : 'html',
            dir : 'docs/coverage/'
        ,

        logLevel: 'LOG_DEBUG',

        // web server port
        port: 9876,


        // enable / disable colors in the output (reporters and logs)
        colors: true,


        // level of logging
        // possible values: config.LOG_DISABLE || config.LOG_ERROR || config.LOG_WARN || config.LOG_INFO || config.LOG_DEBUG
        logLevel: config.LOG_INFO,


        // enable / disable watching file and executing tests whenever any file changes
        autoWatch: false,


        // start these browsers
        // available browser launchers: https://npmjs.org/browse/keyword/karma-launcher
        browsers: ['PhantomJS'],    // 'Chrome', 


        // Continuous Integration mode
        // if true, Karma captures browsers, runs the tests and exits
        singleRun: true
    )

【讨论】:

我的所有文件都包含在内。我认为这个问题与 browserify 有关。 不幸的是,我不使用 Browserify,但我在集成和测试方面也看到了更多问题。当我遇到问题时,我注意到很多关于 Browserify 的文章和问题,所以很遗憾你可能不得不继续搜索。抱歉,我无法提供更多帮助。

以上是关于Karma + Browserify + Jasmine + 伊斯坦布尔 + React 覆盖的主要内容,如果未能解决你的问题,请参考以下文章

grunt karma 覆盖在 jenkins 上失败,但在 windows/unix 上有效

让 Karma、6to5ify 和伊斯坦布尔打球

如何从代码覆盖率数字中排除 browserify 生成的代码?

在 karma 中使用“tsify”启用“对装饰器的实验性支持”

用业力/茉莉花写测试

业力覆盖未能显示正确的结果