首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >角9-错误: StaticInjectorError[Http]:StaticInjectorError[Http]:NullInjectorError:没有Http提供程序

角9-错误: StaticInjectorError[Http]:StaticInjectorError[Http]:NullInjectorError:没有Http提供程序
EN

Stack Overflow用户
提问于 2020-08-27 05:16:33
回答 1查看 82关注 0票数 0

我刚开始做角度测试。现在,我正在尝试测试服务。当我为我的单元测试运行ng test时,当这些测试使用该服务时,我得到的是错误:

代码语言:javascript
复制
Error: StaticInjectorError[Http]:  
StaticInjectorError[Http]: 
NullInjectorError: No provider for Http!

这是我的规范文件:

代码语言:javascript
复制
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文件导入:

代码语言:javascript
复制
import { Headers, Http } from '@angular/http';
import 'rxjs/add/operator/toPromise';
import { Contact } from '../';
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-08-27 05:33:08

您正在从http中注入@angular/common模块,但是您已经导入了@angular/http模块。

改为:

代码语言:javascript
复制
import { Headers, Http } from '@angular/common/http';

你只需要这个:

代码语言:javascript
复制
imports: [HttpClientTestingModule], 

或者,您可以模拟它而不是实际的ContactService

代码语言:javascript
复制
class MockContactService {
   // properties and methods to mock
}

现在,您可以在您的提供程序中使用它:

代码语言:javascript
复制
providers: [
   {
     provide: ContactService,
     useClass: MockContactService
   }
]
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/63609625

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档