Grunt-mocha-test Xunit记者将整个控制台输出写入xunit文件

时间:2014-02-17 14:40:01

标签: node.js gruntjs mocha xunit

我正在使用grunt-mocha-test来运行我们的mocha测试。我希望能够运行测试并生成xunit报告并获得覆盖率(使用blanket.js)。我的gruntfile中有以下部分:

mochaTest: {
        'unit-jenkins': {
            options: {
                reporter: 'XUnit',
                require: paths.test + '/blanket',
                captureFile: paths.tmp + '/xunit.xml'
            },
            src: [paths.test + '/unit/**/*.js'],        
        },
        'integration-jenkins': {
            options: {
                reporter: 'XUnit',
                require: paths.test + '/blanket',
                captureFile: paths.tmp + '/xunit.xml'
            },
            src: [paths.test + '/integration/**/*.js']
        },
        coverage: {
            options: {
                reporter: 'html-cov',
                quiet: true,
                captureFile: paths.tmp + '/coverage.html'
            },
            src: [paths.test +  '/**/*.js']
        }
    },

    grunt.registerTask('test-jenkins', [
    'mochaTest:unit-jenkins',       // run unit tests
    'mochaTest:integration-jenkins',    // run unit tests
]);

当我运行grunt test-jenkins时,我可以在控制台上看到测试输出和xunit输出。此外,创建了xunit文件,但它包含测试输出和xunit输出,例如:

[14:30:17.164Z] TRACE App: HTTP Response /versions
HTTP/1.1 200 OK
HTTP/1.1 200 OK
X-Powered-By: Express
Content-Type: application/json; charset=utf-8
Content-Length: 46
ETag: "-1409762768"
Date: Mon, 17 Feb 2014 14:30:17 GMT
Connection: close
<testsuite name="Mocha Tests" tests="1" failures="0" errors="0" skipped="0" timestamp="Mon, 17 Feb 2014 14:30:17 GMT" time="0.029">
<testcase classname="Application" name="should contain description of API versions" time="0.028"/>
</testsuite>

如何配置grunt-mocha-test以使xunit输出文件仅包含xunit输出?

2 个答案:

答案 0 :(得分:6)

我遇到了与Selenium相同的问题。我通过以下任务解决了这个问题:

    var outputFile = process.env.MOCHA_OUTPUT_FILE || 'xunit_results.xml';
    grunt.registerTask('cleanXunitFile', 'Remove Selenium/WebDriver output from xunit file', function() {
        if (grunt.file.exists('./' + outputFile)) {
            var file = grunt.file.read('./' + outputFile); 
            if (file.indexOf("<testsuite")) {
                grunt.file.write('./' + outputFile, file.substring(file.indexOf("<testsuite")));
            }
        }
        else {
            grunt.log.error("'cleanXunitFile' task was specified but file " + outputFile + " does not exist.");
        }
    });

答案 1 :(得分:2)

  

我可以在控制台上看到测试输出和xunit输出。此外,创建了xunit文件,但它包含测试输出和xunit输出

我担心这是摩卡的一个知道错误。

有一个待处理的请求尝试解决这些问题,请参阅 https://github.com/visionmedia/mocha/pull/1218