据我了解,存根是被迫采取行动的间谍,例如挑边(即投掷)。我可以/或者伪造返回一定范围的数字是否有意义?
我正在尝试测试一个名为“ Loan.prototype.payment”的“ Loan.prototype.cost”,然后进行一些计算。
在我的代码段的注释掉的部分,我试图创建一个数字范围(“ const rdnPaymentReturn”从85.61到85.63),并将“ payment”属性伪造为该范围(constpaymentSpy)。但是我会收到错误消息:“ AssertionError:预期NaN在27.32..27.56之内”
如果我可以/或者将“ paymentSpy”设置为数字范围(85.61-85.63),我该如何解决此AssertionError问题?
参考:
beforeEach(function() {
l = new Loan();
});
describe('#cost()', function() {
it('should call #payment() and return the correct cost amount', function() {
l.principal = 1000;
l.term = 1;
l.rate = 0.05;
sinon.stub(l, 'payment').callsFake(() =>{ return 85.61; });
expect(l.cost()).to.equal(27.32);
// const rdnPaymentReturn = () =>{
// return Math.random() * (85.63 - 85.61) + 85.61;
// }
//const paymentSpy = sinon.stub(l, 'payment').callsFake(() =>{ return rdnPaymentReturn; });
//expect(l.cost()).to.be.within(27.32, 27.56);
});
});
最佳答案
这不太正确:
const paymentSpy = sinon.stub(l, 'payment').callsFake(() =>{ return rdnPaymentReturn; });
这就是说:存根
payment
具有一个函数,该函数在被调用时返回对函数rdnPaymentReturn
的引用。但是永远不会调用rdnPaymentReturn
。因此,您需要返回调用函数的结果:
const paymentSpy = sinon.stub(l, 'payment').callsFake(() => {
return rdnPaymentReturn()
});
或只是传递函数来调用:
const paymentSpy = sinon.stub(l, 'payment').callsFake(rdnPaymentReturn);
关于javascript - 我可以为一系列结果 stub 吗? “sinon.stub()。callsFake(()=> {})” AssertionError:NaN,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/53453975/