【发布时间】:2019-03-30 07:41:21
【问题描述】:
我有模式服务来打开、确认和关闭对话框,我正在制作它的单元测试文件,但我在 Angular 上遇到错误,这是代码。
modal.service.ts
@Injectable()
export class ModalService {
constructor(private dialog: MatDialog) { }
public open<modalType>(modalComponent: ComponentType<modalType>): Observable<any> {
let dialogRef: MatDialogRef<any>;
dialogRef = this.dialog.open(modalComponent, {
maxWidth: '100vw'
});
console.log(dialogRef)
dialogRef.componentInstance.body = body;
return dialogRef.afterClosed().pipe(map(result => console.log('test'); );
}
}
modal.service.spec.ts
export class TestComponent {}
describe('ModalService', () => {
let modalService: ModalService;
const mockDialogRef = {
open: jasmine.createSpy('open')
};
beforeEach(async(() => {
TestBed.configureTestingModule({
imports: [ MatDialogModule ],
providers: [
ModalService,
MatDialogRef,
{ provide: MatDialog, useClass: MatDialogStub }
]
}).compileComponents();
modalService = TestBed.get(ModalService);
}));
it('open modal', () => {
modalService.open(DummyComponent, '300px');
expect(modalService.open).toHaveBeenCalled();
});
});
所以使用该代码的错误是
TypeError: Cannot read property 'componentInstance' of undefined
你能帮助我如何使这个成功吗?非常感谢您的帮助。
【问题讨论】:
-
检查这个mat对话框的例子,确保所有需要的模块都已经导入stackblitz.com/angular/gxyboyyobmo
-
@DanielC。嘿,谢谢您的建议,但我正在寻找单元测试答案。该服务运行良好,在组件中被调用,但在单元测试中没有
标签: javascript angular unit-testing jasmine karma-jasmine