我在为Angular指令创建单元测试时遇到麻烦。问题在于,在设置inputEl.value并调用input.dispatchEvent(new Event('input'))之后再调用fixture.detectChanges(),输入值将被删除,并且将是一个空字符串(因此,我什至没有得到)在那里测试指令)。
这是我的代码:
@Component({
template: `
<form [formGroup]="formGroup">
<input formControlName="datepicker">
</form>`
})
class TestComponent implements OnInit {
formGroup!: FormGroup;
constructor(private readonly formBuilder: FormBuilder) { }
ngOnInit() {
this.initForm();
}
initForm() {
this.formGroup = this.formBuilder.group({
datepicker: ['']
})
}
}
...
beforeEach(() => {
fixture = TestBed.createComponent(TestComponent);
component = fixture.componentInstance;
fixture.detectChanges();
})
it('should add 23:59:59 sec to the initial date', async () => {
component.ngOnInit();
fixture.detectChanges();
const debugEl: HTMLElement = fixture.debugElement.nativeElement;
const inputEl: HTMLInputElement | null = debugEl.querySelector('input');
const value = 'test';
if(inputEl) {
inputEl.value = value;
inputEl.dispatchEvent(new Event('input'));
fixture.detectChanges();
expect(inputEl.value).toBe(value);
}
});
结果:错误:预期“为'test'。
我在做什么错了?