如何使用Chai-HTTP与Sinon?

时间:2017-10-24 05:47:48

标签: node.js unit-testing sinon chai chai-http

以下是我想测试的路线:

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);
            });
        });
    },

感谢您的帮助!

1 个答案:

答案 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);