如何使用玩笑在回调中获取代码覆盖率?
How to get code coverage inside a callback using jest?
我在代码覆盖方面遇到了问题,无法解决。我正在使用 google 地理编码 API 来查询在回调函数中返回响应的坐标。
Jest 用于测试。
这是带回调的可测试调用:
const geocoder = new google.maps.Geocoder();
geocoder.geocode({address: address}, (results, status) => {
// want to get coverage in this block
// expected test results are OK and logging shows right results
});
这是测试。因为测试的时候默认google.maps不可用,所以找到了这样的解决方案:
it('test', () => {
const constructorSpy = spyOn(google.maps, 'Geocoder');
const geocoder = createSpyObj('Geocoder', ['geocode']);
constructorSpy.and.returnValue(geocoder);
geocoder.geocode = jest.fn((adr, callback) => callback(response, 'OK'));
// expected results that are all OK
});
createSpyObj :
const createSpyObj = (baseName, methodNames): { [key: string]: Mock<any> } => {
let obj: any = {};
for (let i = 0; i < methodNames.length; i++) {
obj[methodNames[i]] = jest.fn();
}
return obj;
};
而google.maps定义在setupTests.js中。不测试时,google.maps 在 react 加载 google map
时可用
window.google = {
maps: {
Geocoder: {},
GeocoderStatus: {
OK: 'OK'
}
}
};
有什么我可以尝试或研究的想法吗?只有覆盖是问题,预期结果很好。
代码覆盖率实际上已经在此实现中正常工作。问题是我没有在只有 'if' 子句的 'if' 子句中访问 'else' 语句。
也可以不监视,但定义为 属性 和 运行 你的测试:
it('test', () => {
Object.defineProperty(google, 'maps', {
value: {
Geocoder: function () {
return {
geocode: jest.fn((adr, callback) => callback(response, 'OK'))
}
}
}
});
// expect..
});
我在代码覆盖方面遇到了问题,无法解决。我正在使用 google 地理编码 API 来查询在回调函数中返回响应的坐标。 Jest 用于测试。
这是带回调的可测试调用:
const geocoder = new google.maps.Geocoder();
geocoder.geocode({address: address}, (results, status) => {
// want to get coverage in this block
// expected test results are OK and logging shows right results
});
这是测试。因为测试的时候默认google.maps不可用,所以找到了这样的解决方案:
it('test', () => {
const constructorSpy = spyOn(google.maps, 'Geocoder');
const geocoder = createSpyObj('Geocoder', ['geocode']);
constructorSpy.and.returnValue(geocoder);
geocoder.geocode = jest.fn((adr, callback) => callback(response, 'OK'));
// expected results that are all OK
});
createSpyObj
const createSpyObj = (baseName, methodNames): { [key: string]: Mock<any> } => {
let obj: any = {};
for (let i = 0; i < methodNames.length; i++) {
obj[methodNames[i]] = jest.fn();
}
return obj;
};
而google.maps定义在setupTests.js中。不测试时,google.maps 在 react 加载 google map
时可用window.google = {
maps: {
Geocoder: {},
GeocoderStatus: {
OK: 'OK'
}
}
};
有什么我可以尝试或研究的想法吗?只有覆盖是问题,预期结果很好。
代码覆盖率实际上已经在此实现中正常工作。问题是我没有在只有 'if' 子句的 'if' 子句中访问 'else' 语句。
也可以不监视,但定义为 属性 和 运行 你的测试:
it('test', () => {
Object.defineProperty(google, 'maps', {
value: {
Geocoder: function () {
return {
geocode: jest.fn((adr, callback) => callback(response, 'OK'))
}
}
}
});
// expect..
});