据我了解,存根是被迫采取行动的间谍,例如挑边(即投掷)。我可以/或者伪造返回一定范围的数字是否有意义?
我正在尝试测试一个名为“ 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/

10-10 20:03