以下是我想测试的路线:
app.post('/api/user', (req, res) => {
dbService.replaceUserOnDuplicate(req.body, function returnResponse(insertedId) {
if (insertedId === 0 || insertedId === req.body.id) {
return res.sendStatus(200);
}
// TODO_MINH: Send an appropriate error to handle by the front-end
return res.send({});
});
});
我可以使用chai-http做这样的事情(伪代码):
it('test', function (done) {
chai.request(server)
.post('/api/user')
.send({ user: SomeUserObject })
.end(function (err, res) {
res.should.have.status(200);
done();
});
});
但是,api / users路由会进行数据库调用。我如何使用sinon来存根这个方法(replaceUserOnDuplicate),以便它返回一个虚拟响应(如0或任何东西)?
有可能吗?我正在查看Chai-HTTP语法,我认为没有空间插入任何Sinon存根方法。
作为参考,这里是dbService(mySQL node.js):
replaceUserOnDuplicate: function(user, callback) {
this.tryConnect().getConnection(function(err, con) {
var sql = queries.ReplaceUserOnDuplicate;
// Insert parameters
con.query(sql, [user.id, user.googleID, user.gender, user.firstName, user.lastName, user.email, user.isProfileSetUp, user.location, user.phoneNumber,
// On Duplicate Key Update parameters
user.googleID, user.gender, user.firstName, user.lastName, user.email, user.isProfileSetUp, user.location, user.phoneNumber],
function (err, result) {
con.release();
if (err) throw err;
return callback(result.insertId);
});
});
},
感谢您的帮助!
答案 0 :(得分:0)
一个潜在的解决方案:如果我使用中间件将req.db的属性设置为我们的dbService对象,那么我可以依赖于在chai-http中注入dbService的调用...通过使用.send()发送它们的参数。我相信.send()可以被链接。
这有效吗?
示例(中间件):
var exposeDb = function(req, resp, next){
req.dbService= dbService;
next();
};
app.use('/api/user', exposeDb, next);