如果我有一个接受两个回调的函数的存根,当存根函数被调用时,我如何连接sinon.js来调用两个回调?
例如,这里有一个我想存根的函数,它接受两个函数作为参数:
function stubThisThing(one, two) {
... one and two are functions ...
... contents stubbed by sinon.js ...
}
我可以用sinon来称呼其中一个论点:
stubbedThing.callsArg(0);
或者
stubbedThing.callsArg(1);
但我似乎不能让两者都被召唤。如果我尝试:
stubbedThing.callsArg(0).callsArg(1);
或者
stubbedThing.callsArg(0);
stubbedThing.callsArg(1);
那么sinon只会调用第二个参数。如果我以另一个顺序连接它,那么sinon将调用第一个参数。然而,我希望两者都被一个接一个地称呼。
这不是一个典型的场景,因为没有多少方法会按顺序调用两个方法,我想这就是为什么它不受支持。但是,冷静一点,解决方案很简单:
var subject = {
method: function(one, two) {}
};
var stub = sinon.stub(subject, 'method', function(one, two) {
one();
two();
});
subject.method(
function() { console.log('callback 1'); },
function() { console.log('callback 2'); });
附注:这也提供了选择是否应首先调用一个或两个的选项。
你为什么不完全跳过罪恶?
var obj = { stubMe: function(cb1, cb2) {} };
var originalMethod = obj.stubMe;
obj.stubMe = function(cv1, cb2) {
//Whatever logic you wish
cb1();
cb2();
};
//Do your test
obj.stubMe = originalMethod; //Restore
这样,如果您愿意,您甚至可以继续使用兴农的API:
var stub = sinon.stub();
obj.stubMe = function(cb1, cb2) {
stub.apply(stub, arguments);
//Rest of whatever logic you wanted here
};
obj.stubMe();
expect(stub.calledOnce()).to.be(true); //That would pass
你觉得怎么样?