我使用jasmine-node测试节点服务器中API端点后面的控制器逻辑。以下是此控制器逻辑通常的样子:
var getSummary = function(req, res) {
var playerId = req.params.playerId;
db.players.getAccountSummary(playerId, function(err, summary) {
if (err) {
logger.warn('Error while retrieving summary for player %d.', playerId, err);
return res.status(500).json({
message: err.message || 'Error while retrieving summary.',
success: false
});
} else {
res.json({success: true, summary: summary});
}
});
};
以下是我成功测试else
块的方法:
describe('GET /api/players/:playerId/summary', function() {
it('should return an object summarizing the player account', function(done) {
request
.get('/api/players/' + playerId + '/summary')
.set('Content-Type', 'application/json')
.set('cookie', cookie)
.expect(200)
.expect('Content-Type', /json/)
.end(function(err, res) {
expect(err).toBeNull(err ? err.message : null);
expect(res.body.success).toBe(true);
expect(res.body.summary).toBeDefined();
done();
});
});
});
这很好用,但由于if
块从未经过测试,因此我的分支覆盖率很低。我的问题是,如何强制错误块在测试中运行?我可以模拟一个设置为返回错误的响应,以便我可以测试记录的正确警告并传回正确的数据吗?
答案 0 :(得分:1)
这取决于你的测试。如果你只想进行单元测试,那么间谍就是你的选择。 您可以存根数据库响应。请注意,在这种情况下,不会调用数据库。它只是模拟。
const db = require('./yourDbModel');
spyOn(db.players, 'getAccountSummary').and.callFake(function(id, cb) {
cb(new Error('database error');
});
request
.get('/api/players/' + playerId + '/summary')
.set('Content-Type', 'application/json')
.set('cookie', cookie)
.expect(500)
// ...
如果您需要功能/集成测试,则需要使用错误的数据来调用您的请求,例如您的数据库中不存在的玩家ID。
request
.get('/api/players/i_am_no_player/summary')
.set('Content-Type', 'application/json')
.set('cookie', cookie)
.expect(500)
// ...