我正在忙于单元测试。我有一个Matdialog形式的Angular材料。
我尝试测试这两个功能:
openEcheqSelectorDialog() {
this.dialog.open(EcheqSelectorComponent, {
width: '600px',
maxHeight: 'calc(100vh - 2em)',
data: {
participant: this.participant
}
});
}
openSchemaSelectorDialog() {
this.dialog.open(SchemaSendDialogComponent, {
width: '600px',
maxHeight: 'calc(100vh - 2em)',
data: {
participant: this.participant
}
});
}
这是完整的组件:
export class DetailComponent implements OnInit {
participant: ParticipantInfoDTO;
constructor(private dialog: MatDialog, route: ActivatedRoute) {
this.participant = route.snapshot.data['participant'];
}
ngOnInit() {
}
openEcheqSelectorDialog() {
this.dialog.open(EcheqSelectorComponent, {
width: '600px',
maxHeight: 'calc(100vh - 2em)',
data: {
participant: this.participant
}
});
}
openSchemaSelectorDialog() {
this.dialog.open(SchemaSendDialogComponent, {
width: '600px',
maxHeight: 'calc(100vh - 2em)',
data: {
participant: this.participant
}
});
}
}
但是如果我在单元测试中这样做:
import { async, TestBed, ComponentFixture } from '@angular/core/testing';
import { ParticipantModule } from '../../participant.module';
import { ActivatedRoute } from '@angular/router';
import { PARTICIPANT_INFO_DTO } from 'src/app/shared/stubs/participant-info-dto.stub';
import { MatDialog } from '@angular/material/dialog';
import { I18nStub } from 'src/app/shared/stubs/i18n-stub';
import { I18n } from '@ngx-translate/i18n-polyfill';
import { DetailComponent } from './detail.component';
import { RouterTestingModule } from '@angular/router/testing';
describe('DetailComponent', () => {
let component: DetailComponent;
let fixture: ComponentFixture<DetailComponent>;
beforeEach(async(() => {
TestBed.configureTestingModule({
imports: [
ParticipantModule,
RouterTestingModule
],
providers: [
MatDialog,
{ provide: ActivatedRoute, useValue: {
snapshot: {
data: {
participant: PARTICIPANT_INFO_DTO[0]
}
}
}},
{ provide: I18n, useValue: I18nStub }
]
}).compileComponents().then( () => {
fixture = TestBed.createComponent(DetailComponent);
component = fixture.componentInstance;
fixture.detectChanges();
});
}));
it('should create the DetailComponent', () => {
fixture.detectChanges();
expect(component).toBeTruthy();
});
it('should open the EcheqSelectorComponent in a MatDialog', () => {
component.openEcheqSelectorDialog();
});
it('Should open the SchemaSelectorDialog in a MatDialog' , () => {
component.openSchemaSelectorDialog();
});
});
然后在茉莉花因果的代码覆盖率中。一切似乎都被覆盖了-它说100%。但是我认为这不是进行单元测试的正确方法。
所以我的问题是:正确吗?
或者我有什么要改进的?
谢谢
我可以给您一些提示进行此工作。您需要创建一个spy
并将其放在expect
上。类似于:
公开对话框服务,以便您可以轻松地对其进行监视
constructor(public dialog: MatDialog, route: ActivatedRoute) {
this.participant = route.snapshot.data['participant'];
}
spec.ts
it('should open the EcheqSelectorComponent in a MatDialog', () => {
spyOn(component.dialog,'open').and.callThrough();
component.openEcheqSelectorDialog();
expect(component.dialog.open).toHaveBeenCalledWith(EcheqSelectorComponent, {
width: '600px',
maxHeight: 'calc(100vh - 2em)',
data: {
participant: this.participant
}
});
});
it('Should open the SchemaSelectorDialog in a MatDialog' , () => {
spyOn(component.dialog,'open').and.callThrough();
component.openSchemaSelectorDialog();
expect(component.dialog.open).toHaveBeenCalledWith(SchemaSendDialogComponent, {
width: '600px',
maxHeight: 'calc(100vh - 2em)',
data: {
participant: this.participant
}
});
});
让我知道这是否对您有用,或者您遇到错误。