AngularJS控制器进行Jasmine测试时,无待处理的请求和未满足的GET请求。
创始人
2024-10-27 10:01:09
0

这个问题很可能是因为在控制器中发起了异步请求,但在测试时没有等待这些请求的结果。可以使用AngularJS内置的$timeout服务来模拟异步请求,并使用Jasmine的done()函数等待结果的返回。示例如下:

describe('MyController', function() {
  var $controller, $rootScope, $httpBackend, $timeout, $http;

  beforeEach(module('myApp'));

  beforeEach(inject(function(_$controller_, _$rootScope_, _$httpBackend_, _$timeout_, _$http_) {
    $controller = _$controller_;
    $rootScope = _$rootScope_;
    $httpBackend = _$httpBackend_;
    $timeout = _$timeout_;
    $http = _$http_;
  }));

  afterEach(function() {
    $httpBackend.verifyNoOutstandingExpectation();
    $httpBackend.verifyNoOutstandingRequest();
  });

  it('should get data from server', function(done) {
    var scope = $rootScope.$new();
    spyOn($http, 'get').and.callThrough();

    $httpBackend.expectGET('/api/data')
      .respond(200, [{name: 'John'}, {name: 'Jane'}]);

    var ctrl = $controller('MyController', {$scope: scope});

    $timeout.flush(); // flush any pending $timeout callbacks

    expect($http.get).toHaveBeenCalled();

    $httpBackend.flush(); // flush the mock data

    expect(scope.data).toBeDefined();
    expect(scope.data.length).toEqual(2);

    done(); // call done() to complete the async test
  });
});

在测试中,我们首先注入所需的变量,然后创建一个控制器实例。我们使用$timeout服务来模拟异步请求,并在期望的GET请求上使用$httpBackend服务。

在测试过程中,我们需要使用$timeout.flush()来强制执行异步请求的回调函数。我们还需要使用$httpBackend.flush()来强制将mock数据返回给控制器。

最后,我们使用Jasmine的done()函数来表示异步测试已经完成。

这样做可以确保我们的控制器在进行异步请求时能正常工作,并且符合AngularJS的最佳实践。

相关内容

热门资讯

7分钟辅助挂!超级三加一视频(... 7分钟辅助挂!超级三加一视频(透视)约战竞技场辅助脚本(详细透视外开挂教程)1、在约战竞技场辅助ai...
9分钟辅助挂!广东闲来辅助(透... 9分钟辅助挂!广东闲来辅助(透视)新九哥智能辅助app(详细透视外开挂教程);无聊就玩这款新九哥智能...
五分钟辅助挂!江西中至黑科技辅... 五分钟辅助挂!江西中至黑科技辅助软件(透视)小闲辅助软件(详细透视外开挂教程)1.江西中至黑科技辅助...
第5分钟辅助挂!阿拉游戏中心作... 第5分钟辅助挂!阿拉游戏中心作弊教程(透视)微乐小程序游戏破解器(详细透视外开挂教程)1、许多玩家不...
交流学习经验!大玩家福建十三水... 交流学习经验!大玩家福建十三水辅助(透视)蜀山四川破解版ios(详细开挂外开挂教程)1、实时大玩家福...
一分钟揭秘!逗娱碰胡辅助器(透... 一分钟揭秘!逗娱碰胡辅助器(透视)新九哥开挂(详细开挂外开挂教程)亲,关键说明,逗娱碰胡辅助器赛季回...
教学盘点!邳州友友辅助软件下载... 教学盘点!邳州友友辅助软件下载(透视)闲逸辅助神器免费(详细开挂外开挂教程)1、上手简单,内置详细流...
分享给玩家!闲聚鱼虾蟹软件脚本... 分享给玩家!闲聚鱼虾蟹软件脚本辅助器(透视)新超凡辅助(详细开挂外开挂教程);闲聚鱼虾蟹软件脚本辅助...
科技揭秘!嘟咪互动修改器(透视... 科技揭秘!嘟咪互动修改器(透视)情怀辅助哪里可以装(详细开挂外开挂教程)情怀辅助哪里可以装辅助器中分...
信息共享!拱趴大菠萝攻略(透视... 信息共享!拱趴大菠萝攻略(透视)新二号辅助(详细开挂外开挂教程)拱趴大菠萝攻略辅助器中分为三种模型:...