最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - Sinon Spy is not called if the spied method is called indirectly - Stack Overflow

programmeradmin7浏览0评论

Problem

In our codebase we have a problem with sinon which can be reproduced with the code snipped below. The thing is that it seems to be that indirect called spies return force false, the console.log clearly states that the method is called but the spy.called remains false.

Code

The following CDN's can be used for the html:

//cdnjs.cloudflare/ajax/libs/sinon.js/1.7.3/sinon-min.js
//cdnjs.cloudflare/ajax/libs/require.js/2.1.14/require.min.js

main.js

require(['myModule'], function(module) {

    //using sinon
    var methodCallerSpy = sinon.spy(module, 'methodCaller')
    console.log(methodCallerSpy); // methodCaller
    module.methodCaller();
    console.log(methodCallerSpy.called); //true


    var methodSpy = sinon.spy(module, 'method');
    console.log(methodSpy); //method
    module.methodCaller();
    console.log(methodSpy.called); // false
    module.method();
    console.log(methodSpy.called); // true

});

And the module

define(function() {
    const method = () => console.log('method called by methodCaller');

    const methodCaller = () => method();

    return{
        method,
        methodCaller
    }
});

Problem

In our codebase we have a problem with sinon which can be reproduced with the code snipped below. The thing is that it seems to be that indirect called spies return force false, the console.log clearly states that the method is called but the spy.called remains false.

Code

The following CDN's can be used for the html:

//cdnjs.cloudflare./ajax/libs/sinon.js/1.7.3/sinon-min.js
//cdnjs.cloudflare./ajax/libs/require.js/2.1.14/require.min.js

main.js

require(['myModule'], function(module) {

    //using sinon
    var methodCallerSpy = sinon.spy(module, 'methodCaller')
    console.log(methodCallerSpy); // methodCaller
    module.methodCaller();
    console.log(methodCallerSpy.called); //true


    var methodSpy = sinon.spy(module, 'method');
    console.log(methodSpy); //method
    module.methodCaller();
    console.log(methodSpy.called); // false
    module.method();
    console.log(methodSpy.called); // true

});

And the module

define(function() {
    const method = () => console.log('method called by methodCaller');

    const methodCaller = () => method();

    return{
        method,
        methodCaller
    }
});
Share Improve this question edited May 12, 2017 at 14:12 Flame_Phoenix 17.6k40 gold badges144 silver badges284 bronze badges asked Sep 25, 2014 at 14:25 jeroenoliemansjeroenoliemans 2364 silver badges9 bronze badges
Add a ment  | 

1 Answer 1

Reset to default 8

The problem is that myModule has two private functions called method() and methodCaller() as well as two methods it exposes with the same names.

Sinon is capable on spying on the exposed methods, but not the internal functions.

When you call module.method() your invoking the exposed method, so Sinon is able to detect the call. However, when you call method.methodCaller(), methodCaller() calls the method() private function directly, and therefore the call is not detected by Sinon.

If you change your methodCaller() function to:

methodCaller = function(){
    this.method();
}

... then Sinon should be able to capture the "indirect" call to method() when calling methodCaller().

发布评论

评论列表(0)

  1. 暂无评论