angularjs – Jasmine SpyOn不止一次使用同样的方法

前端之家收集整理的这篇文章主要介绍了angularjs – Jasmine SpyOn不止一次使用同样的方法前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个角度控制器,其方法可以调用$location.search()两次.

第一次只是$location.search()来返回值.
第二次是$location.search(“foo”,null)来清除它.

我的单元测试中有以下间谍:
spyOn($location,“search”).and.returnValue({foo:“bar”});

看来间谍返回{foo:“bar”},即使我的实现是$location.search(“foo”,null).

我需要一种方法,根据参数为同一个方法设置两个不同的间谍.

我需要这个期望:
期待($location.search()FOO).toEqual(NULL);
在单元测试结束时通过.

解决方法

你可以用不同的方式去做.如果您有时间在测试用例期间更改间谍实现,则可以执行以下操作:

var searchSpy = spyOn($location,'search');

searchSpy.and.returnValue(null);
// do stuff
searchSpy.and.returnValue({ foo: "bar" });
// do other stuff

如果调用是由代码中的方法触发的,并且您无法更改间隙中的间谍实现,那么您可以创建一个接受参数并适当响应的函数

spyOn($location,'search').and.callFake(function(someParam){
  if (someParam) { 
      return { foo: "bar" };
  } else {
      return { foo: null };
  }
});

当然你可以在callFake实现中疯狂地使用逻辑,但要注意,我认为在这种情况下它可能是代码味道.无论如何,快乐的编码!

猜你在找的Angularjs相关文章