Angularjs   发布时间:2022-04-20  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了angularjs – 如何解决$q.all承诺在Jasmine单元测试?大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我的控制器有如下代码
$q.all([qservice.getData($scope.id),dservice.getData(),qTservice.get()])
.then(function (allData) {
  $scope.data1 = allData[0];
  $scope.data2 = allData[1];
  $scope.data3 = allData[2];
});

在我的单元测试中,我做这样的事情:

beforeEach(inject(function($rootScope,$q,$LOCATIOn){// and other dependencies... 
  qserviceSpy = spyOn(_qservice,'getData').andCallFake(function () {
    var data1 = {
      id: 1,sellingProperty: 1,};
    var d = $q.defer();
    d.resolve(data1);
    return d.promise;
  });

  dserviceSpy = spyOn(_dservice,'getData').andCallFake(function () {
    var data2 = [{ "id": "1","anotherProp": 123 }];
    var d = $q.defer();
    d.resolve(data2);
    return d.promise;
  });
  qTserviceSpy = spyOn(_qTservice,'get').andCallFake(function () {
    var data3 = [{ id: 0,name: 'Rahul' }];
    var d = $q.defer();
    d.resolve(data3);
    return d.promise;
  });
  rootScope = $rootScope;
});

现在在我的测试中,我检查如果服务被调用,data1,data2不是未定义。

it('check if qservice' got called,function() {
  expect(scope.data1).toBeUndefined();
  rootScope.$digest();
  expect(_quoteservice.getQuotE).toHaveBeenCalled();
});
it('check if "data1" is defined',function () {
  expect(scope.data1).toBeUndefined();
  rootScope.$digest();
  expect(scope.data1).toBeDefined();
});

我的问题是,这是工作正常,直到我替换我的个人服务调用在控制器与q.all和在测试范围。$ apply与rootScope。使用q.all和rootScope。$ digest(尝试使用范围$ apply)以及两个测试失败,错误

如果我删除rootScope。$ digest然后promises从来没有得到解决和测试失败说

任何帮助我应该如何单元测试代码与q.all?

遇到了this post

但这也没有帮助,因为我已经尝试使用$ digest。

您可以尝试将$ rootScope。$ apply()放在afterEach()回调函数中。 Promises在$ apply()中解析。
afterEach(function(){
    rootScope.$apply();
});

大佬总结

以上是大佬教程为你收集整理的angularjs – 如何解决$q.all承诺在Jasmine单元测试?全部内容,希望文章能够帮你解决angularjs – 如何解决$q.all承诺在Jasmine单元测试?所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。