Unit Test - $httpBackend

$httpBackend是包含在ngMock中的一个服务, 提供伪后台, 模拟$http请求. 让测试代码不用真的发起网络请求.

$httpBackend实例

图片上传服务依托于阿里云, 在初始化Service的时候需要在后台请求认证信息. 我们的目的就是, 在单元测试的时候, 模拟请求认证信息的过程.

发起请求的代码如下, 简单的$http.get()

applyTokenDo(func){
  return this.$http.get(this.API_SERVER + '/api/upload/aliyun-sts', {
        cache: true
    }).then(result => {
      ...
      func();
    });
}

模拟请求通常经历以下三个步骤

  1. 获取$httpBackend服务
  2. 定义伪后台的配置
  3. 调用$httpBackend.flush();
let uploadService, $httpBackend;
beforeEach(angular.mock.inject($injector => {
    uploadService = $injector.get('uploadService');
    //step1
    $httpBackend = $injector.get('$httpBackend');
    //step2
    $httpBackend.when('GET', `${uploadService.API_SERVER}/api/upload/aliyun-sts`).respond(aliyunRes);
}));
it('should invoke callback with OSS client', () => {
    let spy = jasmine.createSpy('spy');
    uploadService.applyTokenDo(spy);
    //step3
    $httpBackend.flush();
    expect(spy.calls.any()).toBeTruthy();
})

$httpBackend常用方法

  1. when 新建一个后端定义
  2. expect 新建一个请求期望

when 和 expect都需要4个参数method, url, data, headers, 其中后2个参数可选。都返回一个带respond()方法的对象.
需要注意以下两点:

  • method表示http方法, 注意都需要是大写(GET, PUT…)
  • url可以为正则或者字符串

它们的区别在于:$httpBackend.expect的伪后台只能被调用一次(调用一次后会被清除), 第二次调用就会报错, 而且$httpBackend.resetExpectations可以移除所有的expect而对when没有影响.

参考

$httpBackend doc

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 136,790评论 19 139
  • 从三月份找实习到现在,面了一些公司,挂了不少,但最终还是拿到小米、百度、阿里、京东、新浪、CVTE、乐视家的研发岗...
    时芥蓝阅读 42,957评论 11 349
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 179,601评论 25 708
  • 工作与爱情竞相折磨
    GX2501阅读 125评论 0 0
  • 睡了两觉醒来才这个点(2014年5月10日04:39),天还没有要亮的意思,可我已经睡饱了,怎么办呢? ...
    艺化阅读 384评论 0 0

友情链接更多精彩内容