Angular的HttpTestingController无法匹配带参数的URL
创始人
2024-10-24 06:00:55
0

当使用HttpTestingController模拟HTTP请求时,有时会出现无法匹配带参数的URL的问题。此时需要通过传递HttpParams对象来解决这一问题。

以下是一个使用HttpParams对象传递参数的代码示例:

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

describe('MyService', () => {
  let service: MyService;
  let httpClient: HttpClient;
  let httpTestingController: HttpTestingController;

  beforeEach(() => {
    TestBed.configureTestingModule({
      imports: [HttpClientTestingModule],
      providers: [MyService]
    });

    service = TestBed.inject(MyService);
    httpTestingController = TestBed.inject(HttpTestingController);
    httpClient = TestBed.inject(HttpClient);
  });

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

  it('should send request with query string parameter', () => {
    // Define the value we expect to be returned by the mock backend
    const expectedValue = 'value';

    // Set up the request params
    const params = new HttpParams().set('paramName', 'paramValue');

    // Use the HttpClient to send the request and subscribe to the response
    httpClient.get('https://my-api.com/api-endpoint', {params}).subscribe((response) => {
      expect(response).toEqual(expectedValue);
    });

    // Define the mock response and pass it to the expectOne method of the HttpTestingController
    const req = httpTestingController.expectOne('https://my-api.com/api-endpoint?paramName=paramValue');
    req.flush(expectedValue);
  });
});

在上述代码中,我们通过创建一个HttpParams对象并传递给HttpClient的get方法来设置请求的参数。然后,我们使用HttpTestingController的expectOne方法来定义模拟的响应并指定带参数的URL来匹配请求。最后,我们通过调用flush方法将预期的响应返回给请求。

这种做法可以帮助我们解决HttpTestingController无法匹配带参数的URL的问题。

相关内容

热门资讯

技巧知识分享!微扑克辅助工具,... 技巧知识分享!微扑克辅助工具,微扑克ai机器人(微扑克)原来有挂(有挂攻略)-哔哩哔哩1、点击下载安...
重大通报!微扑克辅助软件查得出... 重大通报!微扑克辅助软件查得出来吗,微扑克透牌(微扑克)总是真的有挂(今日头条)-哔哩哔哩1、微扑克...
关于!微扑克辅助算牌器,微扑克... 关于!微扑克辅助算牌器,微扑克如何让系统发好牌(微扑克)竟然是真的有挂(详细教程)-哔哩哔哩1、微扑...
详细说明!微扑克辅助工具,微扑... 您好,微扑克如何让系统发好牌这款游戏可以开挂的,确实是有挂的,需要了解加去威信【136704302】...
实测教程!微扑克系统发牌逻辑,... 实测教程!微扑克系统发牌逻辑,微扑克有挂么(微扑克)原来是真的有挂(有挂头条)-哔哩哔哩微扑克系统发...
总算了解!微扑克辅助插件挂,微... 总算了解!微扑克辅助插件挂,微扑克有挂么(微扑克)真是有挂(有挂方法)-哔哩哔哩;1)微扑克辅助插件...
终于知道!微扑克ai分析器,微... 终于知道!微扑克ai分析器,微扑克如何让系统发好牌(微扑克)一直真的有挂(有挂教学)-哔哩哔哩;该软...
分享认知!微扑克辅牌软件,微扑... 分享认知!微扑克辅牌软件,微扑克如何让系统发好牌(微扑克)确实真的有挂(有挂秘笈)-哔哩哔哩1.微扑...
重大推荐!微扑克有挂么,微扑克... 重大推荐!微扑克有挂么,微扑克有挂么(微扑克)真是真的有挂(有挂神器)-哔哩哔哩;1、下载好微扑克有...
玩家必知教程!微扑克辅助测试,... 玩家必知教程!微扑克辅助测试,微扑克有挂么(微扑克)其实真的有挂(有挂解惑)-哔哩哔哩;1、微扑克辅...