javascript - MatDialog 服务单元测试 Angular 6 错误

标签 javascript angular unit-testing jasmine karma-jasmine

我有模式服务来打开、确认和关闭对话框,我正在制作它的单元测试文件,但我在 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-dialogs 可能很棘手。我倾向于使用 spy 对象从打开的对话框(下面的 dialogRefSpyObj)返回,这样我可以更轻松地跟踪和控制测试。在您的情况下,它可能类似于以下内容:

describe('ModalService', () => {
    let modalService: ModalService;
    let dialogSpy: jasmine.Spy;
    let dialogRefSpyObj = jasmine.createSpyObj({ afterClosed : of({}), close: null });
    dialogRefSpyObj.componentInstance = { body: '' }; // attach componentInstance to the spy object...

    beforeEach(() => {
        TestBed.configureTestingModule({
            imports: [MatDialogModule],
            providers: [ModalService]
        });
        modalService = TestBed.get(ModalService);
    });

    beforeEach(() => {
        dialogSpy = spyOn(TestBed.get(MatDialog), 'open').and.returnValue(dialogRefSpyObj);
    });

    it('open modal ', () => {
        modalService.open(TestComponent, '300px');
        expect(dialogSpy).toHaveBeenCalled();

        // You can also do things with this like:
        expect(dialogSpy).toHaveBeenCalledWith(TestComponent, { maxWidth: '100vw' });

        // and ...
        expect(dialogRefSpyObj.afterClosed).toHaveBeenCalled();
    });
});

关于javascript - MatDialog 服务单元测试 Angular 6 错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52993583/

相关文章:

javascript - 如何在按下按钮或 div 时更改背景颜色,如果按下另一个,第一个变回颜色?

javascript - 如何编辑 svg 并将其作为数据发送

ruby-on-rails - 如何从 Rails 集成测试访问 session ?

angular - 单元测试 Angular Material 对话框 - 如何包含 MAT_DIALOG_DATA

javascript - 未在 Angular 8 的 Post API Call 中发送授权承载 token

javascript - Angular :错误类型错误:无法读取未定义的属性 ___

php - 提交按钮可以在不刷新 AJAX 的情况下工作吗?

angular - 无法读取 ionic 搜索栏中未定义错误的属性 'toLowerCase'?

Angular 路由器过渡动画有条件地左右滑动

android - Android 单元测试中的模拟改造 Observable<T> 响应