方法未获取更改事件的单元测试代码覆盖率

时间:2021-07-29 09:01:01

标签: javascript angular unit-testing jasmine karma-jasmine

我正在我的 Angular 应用程序上运行 Jasmine 测试。我创建了一个通过的测试,我认为它会涵盖我的更改事件方法。输入是一组单选按钮。我正在测试的是,触发事件时值发生了变化。

.ts 文件

  onBehalfOfChangeEvent(x) {
        const value = x.value; // this line not covered on report
        this.params.onBehalfOf = value; // this line not covered on report
    }

.html 文件

       <div formGroupName="onBehalfOfGroup" class="form-group">
        <div *ngFor="let radio of onBehalfOfArray; let i = index">
        <label class="col-12 customradio"
          ><span>{{ radio.value }}</span>
          <input
            [ngClass]="{ checked: registerForm.get('onBehalfOfGroup.onBehalfOf').value == params.onBehalfOf }"
            class="radioBtn"
            id="radio-{{ i }}"
            type="radio"
            [value]="radio.value"
            name="onBehalfOf"
            formControlName="onBehalfOf"
            (change)="onBehalfOfChangeEvent(radio)"
          />
          <span class="checkmark"></span>
        </label>
        </div>
    </div>

.spec 文件

  it('should trigger onBehalfOfChangeEvent method on change', () => {
        const testee = component;
        expect(testee).toBeTruthy();
        let de = fixture.debugElement.query(By.css('.radioBtn'));
        spyOn(testee, 'onBehalfOfChangeEvent');
        de.triggerEventHandler('change', {});

        const x = { value: 'Self' };
        const value = x.value;
        component.onBehalfOfChangeEvent(value);
        expect(testee.onBehalfOfChangeEvent).toHaveBeenCalled();
        expect(component.params.onBehalfOf).toEqual(value);
    });

有人能明白为什么没有覆盖这两行吗?这是一个 stackBlitz - https://stackblitz.com/edit/angular-queryparam-gbb23f?file=src/app/app.component.spec.ts

1 个答案:

答案 0 :(得分:1)

你安排间谍的方式导致测试出错。您不是在调用 onBehalfOfChangeEvent 的实际实现,而是覆盖它(使用您的间谍)并使其在调用时不执行任何操作。

这是由于这一行:

spyOn(testee, 'onBehalfOfChangeEvent');

相反,您想要编辑它以指定一个间谍,以及调用原始方法:

spyOn(testee, 'onBehalfOfChangeEvent').and.callThrough();

现在只需更改调用事件处理程序的方式

de.triggerEventHandler('change', {});

de.triggerEventHandler('change', x);

你可以走了。

您还需要声明并初始化变量 x 才能使用它。请注意这个陷阱。