如何使用$promise.then在jasmine规范中模拟AngularJS $资源

前端之家收集整理的这篇文章主要介绍了如何使用$promise.then在jasmine规范中模拟AngularJS $资源前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我使用$resource来设置一些API调用,而在测试时我采用了注入$qand的一般方法

mockMyService.doSomethingAsync.andReturnValue($q.when(successResponse))

这已经很好了,但是,我有一个类似于以下的方法

  1. # MyService
  2. MyService.doSomethingAsync(params).$promise.then ->
  3. $scope.isLoading = false
  4.  
  5. # MyService Spec
  6. mockMyService =
  7. doSomethingAsync: jasmine.createSpy('doSomethingAsync')
  8.  
  9. it 'calls service #doSomethingAsync',->
  10. inject ($q) -> mockMyService.doSomethingAsync.and.returnValue($q.when(response))
  11. controller.methodThatWrapsServiceCall()
  12. scope.$apply()
  13.  
  14. expect(mockMyService.doSomethingAsync).toHaveBeenCalled()

不幸的是,当$promise.then在最后被链接时,上面概述的模拟策略似乎不起作用.我最终得到以下错误

  1. TypeError: 'undefined' is not an object (evaluating 'MyService.doSomethingAsync(params).$promise.then')

简单地以doSomethingAsync().$promise结束的方法使用此模拟策略传递测试而没有问题.

(其他信息:这些是与Karma和PhantomJS一起运行的Jasmine测试)

实际上,想通了!

我刚刚改变了我的模拟以返回and.returnValue({$promise:$q.when(response)})

猜你在找的Angularjs相关文章