茉莉花测试,功能未被调用

问题描述 投票:0回答:1

我正在测试一个验证器,它调用一个服务,如果返回零,它将返回一个错误对象。

我已经使用returnValue为服务创建了一个间谍,它似乎工作正常,但是我在执行验证函数并返回值时遇到了困难。

我最终做的是为我正在测试的功能创建一个间谍,我认为我不应该这样做。

验证器功能:

它将服务作为参数并在内部使用

static require(service: Service): ValidatorFn {
   return (formGroup: FormGroup): { [key: string]: boolean } | null => {
      const checkedCount = state.currentCount();
      if (checkedCount === 0) {
          return  {
            'isNotChecked' : true
          };
        }
      return null;
    };
  }

测试,这是有效的:正如我所说,我真的不认为我应该监视我正在测试的功能?

  it('should return error object when currentCount === 0', () => {
        spyOn(service, 'currentCount').and.returnValue(0);
        spyOn(ModValidation, 'require').and.returnValue({ 'isNotChecked' : true });
        service.currenCount();
        expect(ModValidation.require(service)).toEqual({ 'isNotChecked' : true });
    });

我尝试过但不起作用的是:

  it('should return error object when currentCount === 0', () => {
        spyOn(service, 'currentCount').and.returnValue(0);
        const resp = ModValidation.require(service);
        service.currentCount();
        expect(resp).toEqual({ 'isNotChecked' : true });
    });

我明白了

Expected Function to equal Object({ isNotChecked: true }).
angular typescript jasmine
1个回答
1
投票

问题是,验证器中的require方法是将AbstractControl转换为验证结果的函数。

所以你想要的是这样的:

it('currentCount 0', () => {
    const service = {currentCount: () => {}};
    spyOn(service, 'currentCount').and.returnValue(0);

    expect(CustomValidators.require(service)({} as any)).toEqual({
            'isNotChecked' : true
          });
  });

我为你做了一个Stackblitz检查:stackblitz

© www.soinside.com 2019 - 2024. All rights reserved.