我正在用AngularJS编写应用程序。我正在为因果报应和茉莉花的角度服务编写单元测试。它无法正常工作,因为单元测试不断给我这些错误:
预计将调用间谍照片。
这是我的Codepen中的错误: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;
}
答案 0 :(得分:1)
该测试正在监视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);