I am getting HttpClient null injector error while running the test using Jasmine. I have mocked the service and still get the error. I am not sure why ?
import { async, ComponentFixture, TestBed } from '@angular/core/testing';
import { SpreadsheetComponent } from '../spreadsheet/spreadsheet.component';
import { SpreadsheetService } from '../../services/spreadsheet/spreadsheet.service';
import { Mock } from 'ts-mocks';
import { of } from 'rxjs';
import { FormsModule } from '@angular/forms';
fdescribe('SpreadsheetComponent', () => {
let component: SpreadsheetComponent;
let fixture: ComponentFixture<SpreadsheetComponent>;
let mockSpreadSheetService;
const xmlData =
`
<?xml version="1.0" encoding="UTF-16"?>
<Reports>
<Report>
<Name>F 20.04</Name>
<ReportVal>
<ReportRow>10</ReportRow>
<ReportCol>10</ReportCol>
<Val>100</Val>
</ReportVal>
<ReportVal>
<ReportRow>10</ReportRow>
<ReportCol>11</ReportCol>
<Val>200</Val>
</ReportVal>
<ReportVal>
<ReportRow>10</ReportRow>
<ReportCol>12</ReportCol>
<Val>0</Val>
</ReportVal>
<ReportVal>
<ReportRow>20</ReportRow>
<ReportCol>10</ReportCol>
<Val>600</Val>
</ReportVal>
<ReportVal>
<ReportRow>20</ReportRow>
<ReportCol>11</ReportCol>
<Val>500</Val>
</ReportVal>
<ReportVal>
<ReportRow>20</ReportRow>
<ReportCol>12</ReportCol>
<Val>600</Val>
</ReportVal>
</Report>
</Reports>
`
;
beforeEach(async(() => {
TestBed.configureTestingModule({
declarations: [SpreadsheetComponent],
providers: [{SpreadsheetService, useFactory: () => mockSpreadSheetService.Object}]
})
.compileComponents();
}));
beforeEach(() => {
mockSpreadSheetService = new Mock<SpreadsheetService>({
loadXML: () => of(xmlData)
});
fixture = TestBed.createComponent(SpreadsheetComponent);
component = fixture.componentInstance;
fixture.detectChanges();
});
it('should create', () => {
// fixture.detectChanges();
expect(component).toBeTruthy();
});
});