要使用Jest测试使用axios的httpClient,您可以使用Jest提供的模拟功能来伪造对外部API的请求和响应。下面是一个示例测试的代码:
首先,安装所需的依赖:
npm install axios axios-mock-adapter jest --save-dev
然后,创建一个名为httpService.test.js的测试文件,编写以下代码:
import axios from 'axios';
import MockAdapter from 'axios-mock-adapter';
import { post } from './httpService';
describe('httpService', () => {
let mock;
beforeEach(() => {
mock = new MockAdapter(axios);
});
afterEach(() => {
mock.reset();
});
it('should make a POST request', async () => {
const url = 'http://test.com/api';
const data = { name: 'John', age: 30 };
const responseData = { success: true };
mock.onPost(url, data).reply(200, responseData);
const result = await post(url, data);
expect(result).toEqual(responseData);
});
it('should throw an error for failed request', async () => {
const url = 'http://test.com/api';
const data = { name: 'John', age: 30 };
mock.onPost(url, data).reply(500);
await expect(post(url, data)).rejects.toThrow('Error in POST request');
});
});
在上面的示例中,我们使用MockAdapter来创建一个虚拟的axios实例,然后设置它的响应。在第一个测试中,我们模拟了一个成功的POST请求,并验证返回的数据是否与预期的responseData匹配。在第二个测试中,我们模拟了一个失败的POST请求,并验证是否抛出了一个包含特定错误消息的错误。
运行这个测试文件时,Jest将使用模拟的axios进行请求,而不会实际发送请求到外部API。这样您就可以测试您的httpService中的逻辑,包括对API响应的处理。
请注意,这个示例只测试了httpService的post方法。根据您的需求,您可以编写更多的测试来验证不同的场景和方法。