我可以更改jasmine-node的输出以显示控制台中的传递测试以及失败吗?

时间:2015-09-21 07:15:58

标签: node.js testing jasmine

我运行node test.js时会运行以下文件。

var Jasmine = require('jasmine');
var jasmine = new Jasmine();
var request = require('request');

describe("test", function(){
    it("works", function(){
        expect(5 + 2).toEqual(4);
    });

    it("should respond with hello world", function(done){
        request('http://localhost:3000/', function(err, res, body){
            expect(body).toEqual('hello world');
            done();
        })
    });
})

jasmine.execute();

这给了我以下输出:

Started
F.

Failures:
1) test works
  Message:
    Expected 7 to equal 4.
  Stack:
    Error: Expected 7 to equal 4.
        at Object.<anonymous> 

2 specs, 1 failure
Finished in 0.037 seconds

显然,一个失败,显示F,一个通过,显示点。我是否可以更改此配置以使其显示通过和失败的测试?

1 个答案:

答案 0 :(得分:5)

您想要使用custom reporter。我建议使用jasmine-console-reporter,这将为您提供格式良好的输出,其中包括所有运行的测试(不仅仅是失败的测试)。您的原始脚本将更改为以下内容:

var Jasmine = require("jasmine");
var jasmine = new Jasmine();
var request = require('request');

// Register a Custom Reporter
const Reporter = require('jasmine-console-reporter');
jasmine.jasmine.getEnv().addReporter(new Reporter());

describe("test", function(){
    it("works", function(){
        expect(5 + 2).toEqual(4);
    }); 

    it("should respond with hello world", function(done){
        request('http://localhost:3000/', function(err, res, body){
            expect(body).toEqual('hello world');
            done();
        })  
    }); 
})

jasmine.execute();

请注意,如果您使用jasmine命令行来运行测试(因此Jasmine已将其帮助程序导出到您的命名空间中),您的代码将如下所示:

const Reporter = require('jasmine-console-reporter');
jasmine.getEnv().addReporter(new Reporter());

我个人觉得最简单的方法是使用 Gulp gulp-jasmine来明确定义并在一个地方,同时还允许我在测试之前运行构建步骤:< / p>

const gulp = require('gulp');
const jasmine = require('gulp-jasmine');
const Reporter = require('jasmine-console-reporter');

gulp.task('default', function() {
    gulp.src('spec/**/*.js')
        .pipe(jasmine({
            reporter: new Reporter()
        }));
});