首页 > 解决方案 > 未在内部函数上调用预期的间谍

问题描述

我正在用 AngularJS 编写一个应用程序。我正在用业力和茉莉花为我的角度服务编写单元测试。它没有按预期工作,因为单元测试不断给我这些错误:

预期的间谍照片已被调用。

这是我的代码笔与错误:https ://codepen.io/aubz/pen/zXyvbj

这是我的单元测试的代码片段:

  it('should process the plain clocking settings', function () {

    ClockingRecordTypeFactory.getRecord('plain', 'here', null, null, null, null, null);

    spyOn(ClockingRecordTypeFactory, 'plain').and.callFake(function () {});
    spyOn(ClockingRecordTypeFactory, 'photo').and.callFake(function () {});
    spyOn(ClockingRecordTypeFactory, 'geo').and.callFake(function () {});
    spyOn(ClockingRecordTypeFactory, 'manual').and.callFake(function () {});

    expect(ClockingRecordTypeFactory.plain).toHaveBeenCalled();
    expect(ClockingRecordTypeFactory.photo).not.toHaveBeenCalled();
    expect(ClockingRecordTypeFactory.geo).not.toHaveBeenCalled();
    expect(ClockingRecordTypeFactory.manual).not.toHaveBeenCalled();

});

以及我要测试的功能:

function getRecord(type, origin, coords, imageData, comments, reason, date) {

    var record = getBaseClockingRecord();

    if (type === 'plain') {
        plain(record);
    }

    if (type === 'photo') {
        photo(record);
    }

    if (type === 'geo') {
        geo(record, coords);
    }

    if (type === 'manual') {
        manual(record);
    }

    return record;
}

标签: javascriptangularjsunit-testingkarma-jasmine

解决方案


该测试正在监视,ClockingRecordTypeFactory.plain但实际上该getRecord函数调用了本地函数plain,因此根本不会调用该间谍。

您可以通过如下更改使间谍按预期工作getRecord

if (type === 'plain') {
    this.plain(record);
}

if (type === 'photo') {
    this.photo(record);
}

if (type === 'geo') {
    this.geo(record, coords);
}

if (type === 'manual') {
    this.manual(record);
}

此外,您还需要在调用之前在测试开始时设置您的间谍getRecord

spyOn(ClockingRecordTypeFactory, 'plain').and.callFake(function () {});
spyOn(ClockingRecordTypeFactory, 'photo').and.callFake(function () {});
spyOn(ClockingRecordTypeFactory, 'geo').and.callFake(function () {});
spyOn(ClockingRecordTypeFactory, 'manual').and.callFake(function () {});

ClockingRecordTypeFactory.getRecord('plain', 'here', null, null, null, null, null);

更新了 Codepen


推荐阅读