Heim > Fragen und Antworten > Hauptteil
Ich verwende vitest, um einige Unit-Tests in meiner Vue-Anwendung durchzuführen. Ich habe einige Tests geschrieben, aber sie schlagen mit der Fehlermeldung fehl: „TypeError: Standardwert ist keine Funktion“. Aber ich verwende in meinem Code keine Funktion namens default().
import getInfo from './info'; vi.mock('axios', () => { return { default: { get: vi.fn() } } }); test('fn getInfo() should request api with axios.get url', async () => { const spyAxios = vi.spyOn(axios, 'get'); await getInfo('1234'); expect(spyAxios).toHaveBeenCalledWith(`${process.env.VUE_APP_API_BASE_URL}`); });
Wenn ich dann npm run test
ausführe, ist das Ergebnis dieses:
FAIL src/api/info/info.test.js > fn getInfo() should request api with axios.get url TypeError: default is not a function ❯ src/api/info/info.test.js:61:22 59| test('fn getInfo() should request api with axios.get url', async () => { 60| const spyAxios = vi.spyOn(axios, 'get'); 61| await getInfo('1234'); | ^ 62| expect(spyAxios).toHaveBeenCalledWith(`${process.env.VUE_APP_API_BASE_URL}`); 63| });Die Datei
info.ts sieht folgendermaßen aus:
import { useLoginStore } from "../../store/LoginStore"; import axios from "axios"; // eslint-disable-next-line export async function getInfo(param: string) : Promise<any> { const loginStore = useLoginStore(); axios.defaults.headers.common = {'Authorization': `Bearer ${loginStore.accessToken}`}; const request = await axios.get( process.env.VUE_APP_API_BASE_URL ); if (request?.status == 200) { return request.data; } else { return null; } }
Weiß jemand, was los ist?
P粉9856865572023-10-30 13:16:50
返回对象中的default
属性不是函数(default: {...}
)。相反,您将返回如下内容:
vi.mock('axios', () => ({ default: () => ({ get: vi.fn(), post: vi.fn(), }), }));