jest.doMock and JSON import mocking



我有这样的代码要测试:

...
import data from '../data/mock.json';
// function is async
export const something = async () => {
try {
...
if (!data) {
throw 'error is here!';
}
return data;
} catch (error) {
return error;
}
};

我的规格看起来是这样的:

...
import { something } from './handler';
describe('handler: something', () => {
beforeEach(() => {
jest.resetModules();
});
describe('on something', () => {
it('should return data', async () => {
const data = [
{
id: 1,
price: '1',
},
{
id: 2,
price: '2',
},
];
jest.doMock('../data/mock.json', () => {
return {
__esModule: true,
default: data,
};
});
await import('../data/mock.json');
await expect(something()).resolves.toEqual(data);
});
it('should return error', async () => {
jest.doMock('../data/mock.json', () => ({
__esModule: true,
default: undefined,
}));
await import('../data/mock.json');
await expect(something()).resolves.toBe('error is here');
});
});
});

不确定原因:但它没有在我的代码中模拟json导入,我希望对其进行测试。我做错了什么?如何让这个导入被"有条件地"嘲笑?因为如果我在文件顶部模拟它(附近的导入(,它会起作用,但对于所有测试用例都是一样的,而我需要在不同的测试用例中使这些数据不同。

jest.doMock不能影响something,因为它已经使用了原始mock.json,需要重新导入,而在测试中重新导入mock.json本身不能影响任何东西。

应该是:

jest.doMock('../data/mock.json', () => ({
__esModule: true,
default: undefined,
}));
const { something } = await import('./handler');
await expect(something()).resolves.toBe('error is here');

最新更新