【发布时间】:2021-11-05 02:13:47
【问题描述】:
我的 Angular 应用程序中有以下 http 拦截器,我想使用 Jasmine 对其进行单元测试。我用谷歌搜索了其中一些并尝试了,但它没有按预期工作。请在下面找到 HttpInterceptorService.ts 文件代码
export class HttpInterceptorService Implements HttpInterceptor {
counter = 0;
constructor(private loaderService: LoaderService) { }
intercept(req: HttpRequest<any>, next: HttpHandler) {
if (req.url !== '/getUsers') {
this.counter ++;
}
this.loaderService.setStatus(true);
return next.handle(req).pipe(
finalize(() => {
if (req.url !== 'getUsers') {
this.counter --;
}
if (this.counter === 0) {
this.loaderService.setStatus(false);
}
};
);
}
}
以下是我目前尝试的 HttpInterceptor.service.spec.ts 文件代码。我不确定如何测试其中的特定方法。
describe('HttpInterceptorService', () => {
let httpService: HttpService;
let httpMock: HttpTestingController;
let interceptor: HttpInterceptorService;
beforeEach(()=> {
TestBed.configureTestingModule({
imports: [HttpClientTestingModule],
providers: [
HttpService,
{provide:HTTP_INTERCEPTOR, useClass: HttpInterceptorService, multi: true},
]
});
httpService = TestBed.get(HttpService);
httpMock = TestBed.get(HttpTestingController);
interceptor = TestBed.get(HttpInterceptorService);
});
it('should increment the counter for all api's expect getUsers', ()=> {
httpService.get('getAdminList').subscribe(res => {
expect(res).toBeTruthy();
expect(interceptor.counter).toBeGreaterThan(0);
});
});
});
在检查参考代码后,我能够通过上述更改覆盖几行代码。但我仍然无法涵盖 finalize 方法。请求帮助。
【问题讨论】:
-
使用
httpMock执行请求并检查实际请求/响应。 angular.io/guide/http#testing-http-requests -
它没有显示任何覆盖的代码,因为您没有在规范中运行任何该代码。您提供的所有代码都没有明显的错误,您的问题也没有,所以请用您尝试过的实际错误或代码更新您的问题,解释什么不符合您的期望。
-
我已经更新了规范代码。我可以用上面更新的代码覆盖几行代码,但我仍然无法覆盖 finalize 方法。任何人都可以在这里提供帮助。
标签: angular unit-testing jasmine angular-http-interceptors