在编写测试用例密码和确认密码PasswordMatching验证指令方面需要帮助

时间:2019-05-27 18:53:21

标签: angular user-interface jasmine karma-runner

我正在为密码不匹配验证器编写单元测试用例,请您帮我编写以下方法的测试规范。

我尝试浏览互联网,但无法设置表单控件的值

export class PasswordMatchingValidation {

  constructor() {}

  static MatchPassword(AC: FormControl) {

    const password = AC.get('password').value; // to get value in input tag
    const confirmPassword = AC.get('confirmPassword').value; // to get value in 

    if (password !== confirmPassword) {

      AC.get('confirmPassword').setErrors({
        MatchPassword: true
      });

    } else {
      return null;
    }
  }

  /**
   * validate if the passwords are matching
   * @param ctrl Takes Form Control
   */
  validate(ctrl: FormControl) {
    return PasswordMatchingValidation.MatchPassword(ctrl);
  }
}

1 个答案:

答案 0 :(得分:0)

好吧,首先,您应该使用一些虚拟数据初始化一个新的FormControl,并使用您先前进行的控制作为参数调用PasswordMatchingValidation.MatchPassword并声明结果。

const control = new FormControl({password: 'whatever'});
describe('PasswordMatchingValidation', () => {
  it('should validate two identical passwords', () => {
    const validation = PasswordMatchingValidation.MatchPassword(control);
    expect(validation).toEqual({ MatchPassword: true });
  });
});

让您的FormControl像应该的那样,当然也要声明相反的情况