简体   繁体   English

"故障单元测试从按钮单击重置角度反应形式控制"

[英]Trouble unit testing angular reactive form control reset from button click

I am facing an issue to write an unit test case in jasmine for my angular application.我在为我的 Angular 应用程序编写 jasmine 单元测试用例时遇到了问题。 Have a reactive form and trying to reset a particular form control from a button click.有一个响应式表单并尝试通过单击按钮重置特定表单控件。 Even though the scenario should be simple enough to test, it seems that I am missing something here.即使场景应该足够简单以进行测试,但我似乎在这里遗漏了一些东西。

Below is the code snippet from the app.以下是应用程序的代码片段。

app.component.html: app.component.html:

<form [formGroup]="userForm" novalidate (ngSubmit)="onSubmit()">
  <div>
    <input
      type="text"
      id="fNameFld"
      name="fName"
      formControlName="fName"
      placeholder="First Name"
    />
    <button (click)="clearField('fName')" id="clrFName">
      Clear First Name
    </button>
  </div>

  <div>
    <input
      type="text"
      id="lNameFld"
      name="lName"
      formControlName="lName"
      placeholder="Last Name"
    />
    <button (click)="clearField('lName')" id="clrLName">Clear Last Name</button>
  </div>

  <div>
    <button type="submit">Submit</button>
  </div>
</form>

app.component.ts app.component.ts

import { FormBuilder, FormGroup } from '@angular/forms';

@Component({
  selector: 'my-app',
  templateUrl: './app.component.html',
  styleUrls: ['./app.component.css'],
})
export class AppComponent implements OnInit {
  name = 'Angular ' + VERSION.major;
  userForm: FormGroup;

  constructor(private readonly fb: FormBuilder) {}

  ngOnInit() {
    this.userForm = this.fb.group({
      fName: this.fb.control(null),
      lName: this.fb.control(null),
    });
  }

  onSubmit() {
    console.log('Submitted Data', this.userForm.value);
  }

  clearField(controlName: string) {
    this.userForm.get(controlName).reset();
  }
}

Unit test code单元测试代码

it('should clear fName control when the "Clear First Name" button is clicked', () => { 
    const spy = spyOn(component, 'clearField');
    const clearBtn = fixture.debugElement.query(By.css("button#clrFName"));
    const form = component.userForm;
    
    form.patchValue({
      'fName': 'John,
      'lName': 'Doe'
    });
    
    clearBtn.nativeElement.click();
    fixture.detectChanges();
    expect(spy).toHaveBeenCalledTimes(1);  // passes
    expect(spy).toHaveBeenCalledWith('fName');  // passes
    expect(form.get('fName').value).toBeNull();  // fails: Expected 'John' to be null.
  });

Angular: 10.0.14角度:10.0.14

Angular CLI: 10.0.8角 CLI:10.0.8

StackBlitz: https://angular-ivy-fc6rik.stackblitz.io StackBlitz: https ://angular-ivy-fc6rik.stackblitz.io

seems like you mocked clearField .好像你嘲笑clearField Add this to actually execute it's content when you mock it:添加它以在您模拟它时实际执行它的内容:

const spy = spyOn(component, 'clearField').and.callThrough();

So everytime clearField is called, it will trigger the spy (so you know if it has been called), and will execute its content .所以每次clearField时,它都会触发 spy(这样你就知道它是否被调用了),并且会执行它的 content 。

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM