Angular单元测试HTTP调用-测试将查询参数分割为查询参数
创始人
2024-10-23 21:30:37
0

使用HttpTestingController拦截HTTP请求并检查查询参数是否正确。示例代码:

import { HttpClientTestingModule, HttpTestingController } from '@angular/common/http/testing';
import { TestBed } from '@angular/core/testing';
import { HttpClient } from '@angular/common/http';

describe('my test', () => {
  let httpClient: HttpClient;
  let httpTestingController: HttpTestingController;

  beforeEach(() => {
    TestBed.configureTestingModule({
      imports: [HttpClientTestingModule],
      providers: [],
    });
    httpClient = TestBed.inject(HttpClient);
    httpTestingController = TestBed.inject(HttpTestingController);
  });

  afterEach(() => {
    httpTestingController.verify();
  });

  it('should send correct query params', () => {
    const searchText = 'test';
    const expectedParams = { q: 'test', limit: 10 };

    httpClient.get('http://example.com/search?q=test&limit=10').subscribe();

    const req = httpTestingController.expectOne((request) => {
      return (
        request.url === 'http://example.com/search' &&
        request.params.get('q') === searchText &&
        request.params.get('limit') === expectedParams.limit.toString()
      );
    });

    req.flush({});
  });
});

在此示例中,我们使用HttpClientTestingModule模块和HttpTestingController类来创建一个模拟的HttpClient实例,并拦截发出的HTTP请求,以检查查询参数是否正确。我们使用expectOne函数来请求HTTP请求,并使用参数谓词来检查请求的URL和查询参数。如果参数匹配,我们将使用req.flush函数来模拟HTTP响应。

请注意,HttpTestingController会自动管理用于拦截HTTP请求的模拟XHR。在每个测试之后,请使用httpTestingController.verify函数来验证没有未处理的请求。

相关内容

热门资讯

透视新版!wepoker辅助工... 透视新版!wepoker辅助工具,智星德州插件2024最新版,2025新版总结(素来是有挂);小薇(...
透视有挂!wepoker辅助器... 透视有挂!wepoker辅助器是真的的吗,wepoker辅助器是真的吗,软件教程(从前是有挂);科技...
透视新版!德普之星辅助功能如何... 透视新版!德普之星辅助功能如何打开,wepoker手机版透视脚本,科技教程(本然是真的有挂);原来确...
透视app!wpk辅助购买,h... 透视app!wpk辅助购买,hhpoker哪个俱乐部靠谱,软件教程(一贯是有挂)wpk辅助购买平台为...
透视代打!wpk辅助购买,竞技... 透视代打!wpk辅助购买,竞技联盟透视插件,攻略教程(本来真的是有挂);支持多人共享记分板与复盘,通...
透视辅助!wepoker透视脚... 1、透视辅助!wepoker透视脚本苹果,hhpoker可以控制牌吗,透明教程(原本是有挂)。2、w...
透视软件!hhpoker透视脚... 透视软件!hhpoker透视脚本视频,wpk透视辅助方法,普及教程(起初是有挂);亲,其实确实真的有...
透视透视!德普之星app安卓版... 透视透视!德普之星app安卓版破解版,wepoker有没有插件,透牌教程(起初真的有挂);德普之星a...
透视透视!wepoker免费永... 透视透视!wepoker免费永久脚本,wepoker怎么破解游戏,科技教程(原生有挂);wepoke...
透视黑科技!aapoker辅助... 自定义aapoker辅助挂系统规律,只需要输入自己想要的开挂功能,一键便可以生成出微扑克专用辅助器,...