Модульное тестирование MatDialog - PullRequest
0 голосов
/ 10 января 2019

Я создаю модульный тест для моего модального подтверждения, использующего MatDialog. Мой первый тест - это базовый тест, который должен создать компонент. Вот мой код для спецификации файла.

import { ComponentFixture, TestBed, async } from '@angular/core/testing';
import { PocitConfirmationModalComponent } from './confirmation-modal.component';
import { MatDialogRef, MAT_DIALOG_DATA } from '@angular/material';
import { CommonModule } from '@angular/common';
import { PortalModule } from '@angular/cdk/portal';
import { MaterialModule } from 'src/app/core/material/material.module';
import { BrowserDynamicTestingModule } from '@angular/platform-browser-dynamic/testing';


class MatDialogRefStub {
    close(param: string) {}
}

describe('PocitConfirmationModalComponent', () => {
  let component: PocitConfirmationModalComponent;
  let fixture: ComponentFixture<PocitConfirmationModalComponent>;


  beforeEach(async(() => {
    TestBed.configureTestingModule({
      imports: [
        CommonModule,
        MaterialModule,
        PortalModule
       ],
      declarations: [PocitConfirmationModalComponent],
      providers: [
          { provide: MatDialogRef, useClass: MatDialogRefStub },
          { provide: MAT_DIALOG_DATA, useValue: {} },
      ]
    }).overrideModule(BrowserDynamicTestingModule, {
        set: {
          entryComponents: [ PocitConfirmationModalComponent ],
        }
    })
    .compileComponents();
  }));

  beforeEach(() => {
    fixture = TestBed.createComponent(PocitConfirmationModalComponent);
    component = fixture.componentInstance;
    fixture.detectChanges();
  });

  it('should create', () => {
    expect(component).toBeTruthy();
  });

});

это файл компонента, который я хочу проверить.

import { Component, OnInit, Inject, ViewEncapsulation } from '@angular/core';
import { MatDialogRef, MAT_DIALOG_DATA } from '@angular/material';
import { ComponentPortal } from '@angular/cdk/portal';

@Component({
  selector: 'pocit-confirmation-modal',
  templateUrl: './confirmation-modal.component.html',
  styleUrls: ['./confirmation-modal.component.scss'],
  encapsulation: ViewEncapsulation.None,
})
export class PocitConfirmationModalComponent implements OnInit {

  portal: ComponentPortal<any>;

  constructor(
    public dialogRef: MatDialogRef<PocitConfirmationModalComponent>,
    @Inject(MAT_DIALOG_DATA) public data: any,
  ) {
    this.portal = new ComponentPortal(this.data.component);
   }

  ngOnInit() {
  }

  action(type: string) {
    this.dialogRef.close(type);
  }

}

после всего этого я получил эту ошибку после запуска теста.

Error: No component factory found for undefined. Did you add it to @NgModule.entryComponents?

Я уже добавил его в entryComponents, но все еще получил эту ошибку.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...