我正在使用Mocha并且应该测试简单的数据库查询,我正在尝试为简单的Moongose架构函数运行异步测试,但每次都会出现超时超时错误。
Error: timeout of 15000ms exceeded
at null.<anonymous> (/usr/local/lib/node_modules/mocha/lib/runnable.js:165:14)
at Timer.listOnTimeout [as ontimeout] (timers.js:110:15)
我甚至使用了 this.timeout(15000)并在mocha命令中尝试了 - timeout 15000 但是没有成功,我给了什么超时时间我我收到这个错误。只有同步测试正在通过。以下是我想测试的测试和功能。
我的摩卡测试: -
describe('#getFacility()', function () {
this.timeout(15000);
it('should get facility successfully', function (done) {
db.getFacilites(Data.testFacility, function (err, facilities) {
if (err) throw err;
facilities.Name.should.equal(Data.testFacility.body.Name);
done();
})
});
});
我的数据:
testFacility : {
params: { clientId:"51c85c3267b6fc1553000001" }
},
我的获取功能
getFacilites: function (req, res) {
Facility.find({Client: req.params.clientId}, function (err, facilities) {
if(err) {
res.send(500,err);
} else if (!facilities) {
res.send(404, "facilities not found");
} else if (req.query.format && req.query.format === 'select') {
var result = facilities.map (function (f) {
return { value: f._id.toString(), text: f.Name }
});
res.json(result);
} else {
console.log("Cannot Retrieve Facilities");
}
});
}
我甚至为查询创建了一个新的单独函数,但它仍然无效。任何功能的想法都是这样的。
describe('#getFacility() direct from DB', function () {
it('should get facility successfully from db', function (done) {
Client_data.Facility.find({Client: Data.testFacility.params.clientId}, function(err, facilities) {
if (err) throw (err);
if (facilities) {
facilities.forEach(function (f) {
console.log(f);
});
done();
}
});
});
});
如果我尝试在查询后调用done()回调,测试通过,但这也不好看 对我来说。
describe('#addFacility()', function () {
it('should add facility successfully', function (done) {
API_Calls.addFacility(Data.testFacility, function (doc) {
doc.Name.should.equal(Data.testFacility.body.Name);
});
done();
});
});
答案 0 :(得分:2)
你的getFacilities正在接受一个req,res和next,你在测试中传递了一些完全不同的东西(一个testFacility对象和一个回调)。
我认为你的getFacilities方法定义不应该使用req,res和next,也许只有clientId和next,然后根据next的回调你可以创建适当的响应。