使用Mocha& amp; amp;测试Express.js res.render诗乃间谍

时间:2016-02-24 08:41:49

标签: javascript unit-testing express mocha sinon

遵循与this example类似的模式我试图在Express.js应用程序中测试我的路线,但我无法让我的间谍验证res.render已经在promise.then包裹时被调用。

这是一个简单的例子,我希望calledOnce为真,但它会返回false。

受测试代码:

var model = {
  get: function() {
    return new Promise(function(res, rej) {
      return res('success');
    });
  }
};

module.exports = function (req, res) {
  model.get().then(function (data) {
    res.render('home', data);
  }).catch(function (err) {
    console.log(err);
  });
};

测试:

var expect = require('chai').expect;
var sinon = require('sinon');
var home = require('./home');

describe('home route', function() {
  it('should return a rendered response', function() {
    var req = {};

    var res = {
      render: sinon.spy()
    };

    home(req, res);

    expect(res.render.calledOnce).to.be.true;
  });
});

1 个答案:

答案 0 :(得分:3)

您必须等待承诺得到解决,这是一种异步操作。

由于Mocha原生支持promises,你可以设置代码将原始的promise一直传递给Mocha,并在链中插入一个测试用例:

// home.js
...
module.exports = function (req, res) {
  // return the promise here
  return model.get().then(function (data) {
    res.render('home', data);
  }).catch(function (err) {
    console.log(err);
  });
};

// test.js
describe('home route', function() {
  it('should return a rendered response', function() {
    var req = {};
    var res = { render: sinon.spy() };

    // Also return the promise here, and add an assertion to the chain.
    return home(req, res).then(function() {
      expect(res.render.calledOnce).to.be.true;
    });
  });
});