Jasmine spyOn on function和返回的对象

时间:2016-02-03 10:06:11

标签: angularjs unit-testing meteor jasmine angular-mock

我正在使用具有角度的MeteorJS并且想要测试控制器。我的控制器使用$ reactive(this).attach($ scope)。如果调用此方法,我需要检查。

我为间谍创造了类似的东西:

var $reactive = function(ctrl) {
    return {
        attach:function(scope) {}
    }
};

所以我可以这样称呼它:

$reactive('aaa').attach('bbb');

我如何在测试中做到这一点?

spyOn($reactive, 'attach');

不起作用。我得到错误:attach()方法不存在

如何检查它是否被调用? 这是一个很好的电话?

expect($reactive).toHaveBeenCalledWith(controller);

如何用args(范围)调用函数attach?

1 个答案:

答案 0 :(得分:4)

您需要模拟$reactive组件。将其替换为在测试范围内返回spyObj的间谍。然后触发使$reactive方法运行和测试的内容。

var reactiveResult = jasmine.createSpyObj('reactiveResult', ['attach']);
var $reactive = jasmine.createSpy('$reactive').and.returnValue(reactiveResult);
var controller = {};
    beforeEach(function () {
      module(function ($provide) {
        $provide.factory('$reactive', $reactive);
      });
      module('yourAppModule');
    });

it('Should call attach', function () {
  $reactive(controller).attach();
  expect($reactive).toHaveBeenCalledWith(controller);
  expect(reactiveResult.attach).toHaveBeenCalled();
}) ;

您也可以向控制器依赖项提供$reactive间谍:

var reactiveResult = jasmine.createSpyObj('reactiveResult', ['attach']);
var $reactive = jasmine.createSpy('$reactive').and.returnValue(reactiveResult);
var ctrl;
    beforeEach(inject(function ($controller) {
      ctrl = $controller('YourController', {$reactive: $reactive });
    }));

it('Should call attach', function () {
  //ctrl.triggerThe$reactiveCall
  expect($reactive).toHaveBeenCalledWith(ctrl);
  expect(reactiveResult.attach).toHaveBeenCalled();
}) ;