从gulp运行时,摩卡测试失败

时间:2016-05-27 23:11:03

标签: node.js gulp mocha

我已经为我的应用程序的服务级别类开发了一套测试,并且当它们在mocha中运行时都会通过,即:

mocha testfile.js

然而,当我从gulp运行它们时,我在其中一个文件中的每个测试都会出现超时错误:

1)预订服务应该创建预订:      错误:超过2000毫秒的超时。确保在此测试中调用done()回调。

2)预订服务应取消预订:      错误:超过2000毫秒的超时。确保在此测试中调用done()回调。

每次测试都

......等等

我的gulpfile看起来像这样:

var serviceTests = [
  './test/block-service-test.js',
  './test/booking-service-test.js',
  './test/location-service-test.js',
  './test/logging-service-test.js'
];

gulp.task('serviceTests', function(){
  gulp.src(serviceTests)
    .pipe(mocha()) 
    .on('end', function() { console.log('>>Finished Running Tests'); })
    .pipe(exit());
});

我唯一能想到的是失败的测试是通过mongoose连接到数据库。这是设置和其中一个测试的示例:

process.env.MONGOLAB_URI = 'mongodb://localhost:27017/TestDB';
process.env.IN_TEST = true;

var mongoose = require('mongoose');
mongoose.Promise = require('bluebird');
mongoose.connect(process.env.MONGOLAB_URI);

describe("booking service", function() {

    var start = moment(new Date());
    var end = moment(start).add(2, 'h');
    var tutorId = "SomeTutorId";
    var userId = "SomeUserId";

    it("should create booking", function(done){
        return bookingService.createBooking(tutorId, userId,  start, end, "123 Anywhere St", "Test", "User", "Tutor", "LastName")
        .then(function(booking){
            assert.notEqual(booking, null);
            done();
        }).catch(function(err){
            console.log(err);
            assert.fail();
            done();
        });
    });
});

为什么他们可以使用摩卡而不是gulp的任何想法?

1 个答案:

答案 0 :(得分:0)

写了一个关闭数据库连接的测试。而不是给予"关闭连接"所有mongoose都会做的错误是超时。