From 86081696546ebd075076a719a89ee272ce1de7c3 Mon Sep 17 00:00:00 2001 From: Joel Davies Date: Fri, 15 Mar 2024 10:34:07 +0000 Subject: [PATCH] Fix remaining broken unit test #1379 --- __mocks__/axios.ts | 5 +---- src/App.test.tsx | 38 +++++++++++++++++++++++++++++++++----- 2 files changed, 34 insertions(+), 9 deletions(-) diff --git a/__mocks__/axios.ts b/__mocks__/axios.ts index 2e6257f2..23d64990 100644 --- a/__mocks__/axios.ts +++ b/__mocks__/axios.ts @@ -3,10 +3,7 @@ const requests = { if (path === '/settings.json') { return Promise.resolve({ data: { - // Set provider to icat as that supports maintenance states needed for App.test.tsx - 'auth-provider': expect.getState().testPath?.includes('App.test') - ? 'icat' - : 'jwt', + 'auth-provider': 'jwt', 'ui-strings': '/res/default.json', plugins: [], 'help-tour-steps': [], diff --git a/src/App.test.tsx b/src/App.test.tsx index 117262cc..085e66b3 100644 --- a/src/App.test.tsx +++ b/src/App.test.tsx @@ -16,12 +16,40 @@ vi.mock('@mui/material', async () => ({ useMediaQuery: vi.fn(), })); -const testToken = - 'eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VybmFtZSI6InRlc3QifQ.hNQI_r8BATy1LyXPr6Zuo9X_V0kSED8ngcqQ6G-WV5w'; +// Needed for the maintenance state update test, has to be hoisted in order to be run before any imports +vi.hoisted(() => { + const testToken = + 'eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VybmFtZSI6InRlc3QifQ.hNQI_r8BATy1LyXPr6Zuo9X_V0kSED8ngcqQ6G-WV5w'; + vi.spyOn(window.localStorage.__proto__, 'getItem').mockImplementation( + (name) => (name === 'scigateway:token' ? testToken : null) + ); +}); -// needed for the maintenance state update test - for some reason it doesn't work when at the beginning of the test itself -window.localStorage.__proto__.getItem = vi.fn().mockImplementation((name) => { - return name === 'scigateway:token' ? testToken : null; +/* Have to remock to replace the auth-provider just for this file. We used to be able to use + expect.getState().testPath?.includes('App.test') inside the __mocks__ folder, but this is undefined + until the tests in this file are actually executed since migrating from Jest to Vitest */ +vi.mock('axios', async () => { + return { + default: { + get: vi.fn((path) => { + if (path === '/settings.json') { + return Promise.resolve({ + data: { + 'auth-provider': 'icat', + 'ui-strings': '/res/default.json', + plugins: [], + 'help-tour-steps': [], + }, + }); + } else { + return Promise.resolve({ + data: {}, + }); + } + }), + post: vi.fn(() => Promise.resolve({ data: {} })), + }, + }; }); describe('App', () => {