Я пытаюсь написать тестовые случаи для метода родительского компонента, которые имеют некоторую зависимость от дочернего компонента.
Я получаю следующую ошибку.
Ошибка: не удается прочитать свойство 'itGroup' из undefined, который является моим дочерним компонентом.
ниже - мой фрагмент кода.
дочерний компонент.
child component:
---------------
----------------
interventionGroup: FormGroup;
constructor() { }
ngOnInit() {
this.itGroup = new FormGroup({
test1: new FormControl(''),
test2: new FormControl(''),
});
}
родительский компонент.
Parent Component mehod where i use the child component instance using view child
----------------------------
changeVal= false;
submitted() {
this.isValidTemplate = this.dynamicTemplateComponent.itGroup.invalid;
if (this.isValidTemplate) {
//logic
} else {
//logic
}
onChange(event){
this.changeval = true;
}
test case for method which have the child component instance which is showing undefined:
---------------------------------------
it('on submit hit service', async () => {
component.onChange(event);
component.changeval = true;
component.submitted();
const spy= spyOn(component, 'submitted');
let button = fixture.debugElement.nativeElement.querySelector('#submitbutton');
button.click();
fixture.detectChanges();
expect(component.submitted).toBeTruthy();
});
<form [formGroup]="TemplateGroup" class="edjustMargin" style="margin-top:20px; width:700px">
<div class="row">
<div>
<div class="col-sm-6">
<label class="labelStyle ">dropdown:</label>
<p-dropdown placeholder="Select val" class="" [options]="Options" formControlName="dropdown" (onChange)="change($event)"></p-dropdown>
</div>
<div *ngIf="changeVal">
<app-dynamic-template ></app-dynamic-template>
</div>
<div *ngIf="changeVal">
<button class="floating" id="submitbutton" type="submit" pButton (click)="submitted()" label="Submit"></button>
<button class="floating" *ngIf="fromPDialog" type="submit" pButton (click)="cancelled()" label="Cancel"></button>
<button class="floating" type="submit" pButton (click)="resetClicked()" label="Clear"></button>
</div>
</form>