2

这是我要测试的路线:

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

谢谢你的帮助!

4

1 回答 1

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);
于 2017-10-24T17:21:27.313 回答