我发出一个 axios 请求,该请求失败并在 catch 块中抛出错误。 在 catch 块中,我正在向其他端点发出请求以获得结果
router.get('/info', (req, res) => {
axios('www.getInformationApi.com')
.then(results => {
return res.status(200).json(results.data);
})
.catch(async(err) => {
if (err === 'server_down') {
try {
// need to improve test coverage for this lines
const secondsResults = await axios('www.getInformationApi2.com');
return res.status(200).json(secondsResults)
} catch (error) {
throw Error(error)
}
} else {
const error = errors.createEntError(err.message, errorList);
return res.status(constants.HTTP_SERVER_ERROR).json(error);
}
})
});
我喜欢编写单元测试,它使用"nock"或"http-mocks"在catch块中涵盖"Axios"请求
是否可以使用单元测试进行测试,或者是否需要在此方案中运行集成测试
根据关于良好单元测试的回答,有这样的说法:
不要测试不属于您的代码
因此,如果您使用的是nock或http-mocks,则您的测试也依赖于axios库。因为如果 axios 有一个错误 - 你的测试可能会显示它。因此,从我的角度来看,将其标记为集成测试更正确。
好的单元测试应该是独立的,并且下来 - axios 库应该是存根的,具有你想要测试的行为,即:
sinon.stub(axios, 'get').rejects('server_down')