javascript – 如何强制茉莉花节点测试中的错误分支

我正在使用茉莉花节点测试我节点服务器中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});
    }
  });
};

下面是我如何成功测试其他块:

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

这很好,但是我的分支覆盖不好,因为如果块没有被测试.我的问题是,如何强制错误块运行在测试中?我可以模拟一个设置为返回错误的响应,以便我可以测试正确的警告是否被记录,正确的数据被传回?

解决方法

这取决于你的测试.如果你只想进行单元测试,间谍是要走的路.
您只需存储数据库响应即可.请注意,在这种情况下,数据库不会被调用.它只是模拟.
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',cookie)
  .expect(500)
  // ...

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


kindeditor4.x代码高亮功能默认使用的是prettify插件,prettify是Google提供的一款源代码语法高亮着色器,它提供一种简单的形式来着色HTML页面上的程序代码,实现方式如下: 首先在编辑器里面插入javascript代码: 确定后会在编辑器插入这样的代码: <pre
这一篇我将介绍如何让kindeditor4.x整合SyntaxHighlighter代码高亮,因为SyntaxHighlighter的应用非常广泛,所以将kindeditor默认的prettify替换为SyntaxHighlighter代码高亮插件 上一篇“让kindeditor显示高亮代码”中已经
js如何实现弹出form提交表单?(图文+视频)
js怎么获取复选框选中的值
js如何实现倒计时跳转页面
如何用js控制图片放大缩小
JS怎么获取当前时间戳
JS如何判断对象是否为数组
JS怎么获取图片当前宽高
JS对象如何转为json格式字符串
JS怎么获取图片原始宽高
怎么在click事件中调用多个js函数
js如何往数组中添加新元素
js如何拆分字符串
JS怎么对数组内元素进行求和
JS如何判断屏幕大小
js怎么解析json数据
js如何实时获取浏览器窗口大小
原生JS实现别踩白块小游戏(五)
原生JS实现别踩白块小游戏(一)