为TestBed提供"entryComponents"

Pav*_*lun 36 javascript unit-testing angular

我有一个组件,它接收组件的组件类,以动态创建为子组件.

let componentFactory = this.componentFactoryResolver.resolveComponentFactory(componentToCreate);
this.componentReference = this.target.createComponent(componentFactory);
Run Code Online (Sandbox Code Playgroud)

我正在尝试编写单元测试并传递一些TestComponent来创建和渲染.

TestBed
  .configureTestingModule(<any>{
    declarations: [MyAwesomeDynamicComponentRenderer, TestHostComponent],
    entryComponents: [TestComponent],
  });
Run Code Online (Sandbox Code Playgroud)

有铸造到"任何"因为configureTestingModule期望TestModuleMetadata没有,entryComponents但我得到错误:"没有为TestComponent找到组件工厂".

我怎样才能提供entryComponentsTestBed

Ale*_*lex 71

如果需要,您也可以直接在测试文件中执行以下操作:

import { BrowserDynamicTestingModule } from '@angular/platform-browser-dynamic/testing'; // DO not forget to Import

TestBed.configureTestingModule({
  declarations: [ MyDynamicComponent ],
}).overrideModule(BrowserDynamicTestingModule, {
  set: {
    entryComponents: [ MyDynamicComponent ],
  }
});
Run Code Online (Sandbox Code Playgroud)

  • 从'@ angular/platform-b​​rowser-dynamic/testing'导入{BrowserDynamicTestingModule}; 如果这有助于任何人 (10认同)
  • 我认为这是解决这个问题的正确答案,这应该被接受. (2认同)

Pav*_*lun 60

好的,我明白了.在测试中,您应该定义新模块,在其中声明模拟组件并将其指定为模块组件entryComponent.

@NgModule({
  declarations: [TestComponent],
  entryComponents: [
    TestComponent,
  ]
})
class TestModule {}
Run Code Online (Sandbox Code Playgroud)

并将其导入 TestBed

TestBed
  .configureTestingModule({
    declarations: [ValueComponent, TestHostComponent],
    imports: [TestModule],
  });
Run Code Online (Sandbox Code Playgroud)

我希望它会帮助某人:]