0

我定义了一个 requirejs 模块来提供一个获取浏览器宽度的函数:

浏览器工具.js

define(['jquery'], function($) {
    return {
        getBrowserWidth: function() {
            return $(window).width();
        }
    }
});

现在我想为它编写单元测试,所以我想模拟jquery

define(['jquery', 'browserTool'], function(jquery, browserTool) {
   describe("test", function() {
      it("should do something", function() {
         spyOn(jquery, "apply").and.returnValue({
            width: function() { return 300; }
         }); 
         expect(browserTool.getBrowserWidth()).toEqual(300);
      });
   });
});

你可以看到我想用:spyOn(jquery, "apply")来模拟,但是这个测试不起作用,似乎我发现了一个错误的方法。

如何解决?

4

1 回答 1

2

您不能直接监视 jQuery 选择器,因为它们每次都返回不同的对象。当您无法获得参考时,一个通用的 Jasmine SpyOn 技巧是将间谍放置在原型上。使用 jQuery,它看起来像这样:

//spyOn $(window).width():
spyOn($.fn, 'width').

如果你愿意,你可以从 spy 调用的参数中提取参数(并看到它是在窗口上调用的)。

至于apply:apply是一个纯javascript方法,不是jQuery的一部分,所以你大概可以通过它所属的函数原型来窥探它:

spyOn(Function.prototype, 'apply');

(虽然我没有尝试过这段代码)

于 2014-09-30T15:50:37.990 回答