我正在为密码不匹配验证器编写单元测试用例,请您帮我编写以下方法的测试规范。
我尝试浏览互联网,但无法设置表单控件的值
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);
}
}
答案 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
像应该的那样,当然也要声明相反的情况