Angular 9 - Error: StaticInjectorError[Http]: StaticInjectorError[Http]: NullInjectorError: No provider for Http
Angular 9 - Error: StaticInjectorError[Http]: StaticInjectorError[Http]: NullInjectorError: No provider for Http
我是 Angular 测试的新手。现在我正在尝试测试 services。
当我 运行 ng test
进行单元测试时,以及当这些测试使用该服务时,
我收到错误:
Error: StaticInjectorError[Http]:
StaticInjectorError[Http]:
NullInjectorError: No provider for Http!
这是我的规范文件:
import { TestBed, inject } from "@angular/core/testing";
import { ContactService } from "./contact.service";
import { HttpClientTestingModule, HttpTestingController } from '@angular/common/http/testing';
import {HttpClientModule} from '@angular/common/http';
describe("ContactService", () => {
beforeEach(() => {
TestBed.configureTestingModule({
imports: [HttpClientTestingModule, HttpClientModule],
providers: [ContactService],
});
});
it("should ...", inject([ContactService], (service: ContactService) => {
expect(service).toBeTruthy();
}));
});
这是我的 .sevice.ts 文件导入:
import { Headers, Http } from '@angular/http';
import 'rxjs/add/operator/toPromise';
import { Contact } from '../';
您正在从 @angular/common
注入 http
模块,但您导入了 @angular/http
模块。
改为:
import { Headers, Http } from '@angular/common/http';
你只需要这个:
imports: [HttpClientTestingModule],
或者您可以模拟它而不是实际的 ContactService
:
class MockContactService {
// properties and methods to mock
}
现在您可以在您的提供商中使用它:
providers: [
{
provide: ContactService,
useClass: MockContactService
}
]
我是 Angular 测试的新手。现在我正在尝试测试 services。
当我 运行 ng test
进行单元测试时,以及当这些测试使用该服务时,
我收到错误:
Error: StaticInjectorError[Http]:
StaticInjectorError[Http]:
NullInjectorError: No provider for Http!
这是我的规范文件:
import { TestBed, inject } from "@angular/core/testing";
import { ContactService } from "./contact.service";
import { HttpClientTestingModule, HttpTestingController } from '@angular/common/http/testing';
import {HttpClientModule} from '@angular/common/http';
describe("ContactService", () => {
beforeEach(() => {
TestBed.configureTestingModule({
imports: [HttpClientTestingModule, HttpClientModule],
providers: [ContactService],
});
});
it("should ...", inject([ContactService], (service: ContactService) => {
expect(service).toBeTruthy();
}));
});
这是我的 .sevice.ts 文件导入:
import { Headers, Http } from '@angular/http';
import 'rxjs/add/operator/toPromise';
import { Contact } from '../';
您正在从 @angular/common
注入 http
模块,但您导入了 @angular/http
模块。
改为:
import { Headers, Http } from '@angular/common/http';
你只需要这个:
imports: [HttpClientTestingModule],
或者您可以模拟它而不是实际的 ContactService
:
class MockContactService {
// properties and methods to mock
}
现在您可以在您的提供商中使用它:
providers: [
{
provide: ContactService,
useClass: MockContactService
}
]