遵循与this example类似的模式我试图在Express.js应用程序中测试我的路线,但我无法让我的间谍验证res.render
已经在promise.then
包裹时被调用。
这是一个简单的例子,我希望calledOnce
为真,但它会返回false。
受测试代码:
var model = {
get: function() {
return new Promise(function(res, rej) {
return res('success');
});
}
};
module.exports = function (req, res) {
model.get().then(function (data) {
res.render('home', data);
}).catch(function (err) {
console.log(err);
});
};
测试:
var expect = require('chai').expect;
var sinon = require('sinon');
var home = require('./home');
describe('home route', function() {
it('should return a rendered response', function() {
var req = {};
var res = {
render: sinon.spy()
};
home(req, res);
expect(res.render.calledOnce).to.be.true;
});
});
答案 0 :(得分:3)
您必须等待承诺得到解决,这是一种异步操作。
由于Mocha原生支持promises,你可以设置代码将原始的promise一直传递给Mocha,并在链中插入一个测试用例:
// home.js
...
module.exports = function (req, res) {
// return the promise here
return model.get().then(function (data) {
res.render('home', data);
}).catch(function (err) {
console.log(err);
});
};
// test.js
describe('home route', function() {
it('should return a rendered response', function() {
var req = {};
var res = { render: sinon.spy() };
// Also return the promise here, and add an assertion to the chain.
return home(req, res).then(function() {
expect(res.render.calledOnce).to.be.true;
});
});
});