目前我正在尝试测试一个子组件,它接受来自主机组件的输入,并在 ngOnInit 生命周期钩子中使用,如下面的代码。
@Component({
selector: 'my-child-component',
template: '<div></div>'
})
class ChildComponent implements OnInit {
@Input() myValue: MyObject;
transformedValue: SomeOtherObject;
ngOnInit():void {
// Do some data transform requiring myValue
transformedValue = ...;
}
}
@Component({
template:`<my-child-component [myValue]="someValue"></my-child-component>`
})
class HostComponent {
someValue: MyObject = new MyObject(); // how it is initialized it is not important.
}
在这种情况下,应该如何测试 ChildComponent,其中 myValue 需要在创建时出现,同时能够访问 ChildComponent.transformedValue 进行断言。
我尝试使用这样的 Angular TestBed 类创建 ChildComponent
componentFixture = testBed.createComponent(LoginFormComponent)
但是 ngOnInit 已经被调用到我调用的位置
fixture.componentInstance.myValue = someValue;
我还尝试创建 HostComponent 的固定装置,虽然它有效,但我无法访问已创建的 ChildComponent 实例,我需要在 ChildComponent.transformedValue 字段上执行断言。
非常感谢您的帮助!
非常感谢!