X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/47e0dc87fa82bac593c53518e556ba7c55410288..3ec7057e490b3d19b15663dd312328f637fa1d3b:/src/store/auth/auth-reducer.test.ts diff --git a/src/store/auth/auth-reducer.test.ts b/src/store/auth/auth-reducer.test.ts index ea08e58983..a7419286a2 100644 --- a/src/store/auth/auth-reducer.test.ts +++ b/src/store/auth/auth-reducer.test.ts @@ -2,8 +2,8 @@ // // SPDX-License-Identifier: AGPL-3.0 -import { authReducer } from "./auth-reducer"; -import { authActions } from "./auth-action"; +import { authReducer, AuthState } from "./auth-reducer"; +import { AuthAction, authActions } from "./auth-action"; import { API_TOKEN_KEY, USER_EMAIL_KEY, @@ -12,18 +12,21 @@ import { USER_OWNER_UUID_KEY, USER_UUID_KEY } from "../../services/auth-service/auth-service"; -import { API_HOST } from "../../common/api/server-api"; import 'jest-localstorage-mock'; +import { createServices } from "../../services/services"; describe('auth-reducer', () => { + let reducer: (state: AuthState | undefined, action: AuthAction) => any; + beforeAll(() => { localStorage.clear(); + reducer = authReducer(createServices("/arvados/v1")); }); it('should return default state on initialisation', () => { const initialState = undefined; - const state = authReducer(initialState, authActions.INIT()); + const state = reducer(initialState, authActions.INIT()); expect(state).toEqual({ apiToken: undefined, user: undefined @@ -40,7 +43,7 @@ describe('auth-reducer', () => { localStorage.setItem(USER_UUID_KEY, "uuid"); localStorage.setItem(USER_OWNER_UUID_KEY, "ownerUuid"); - const state = authReducer(initialState, authActions.INIT()); + const state = reducer(initialState, authActions.INIT()); expect(state).toEqual({ apiToken: "token", user: { @@ -56,7 +59,7 @@ describe('auth-reducer', () => { it('should store token in local storage', () => { const initialState = undefined; - const state = authReducer(initialState, authActions.SAVE_API_TOKEN("token")); + const state = reducer(initialState, authActions.SAVE_API_TOKEN("token")); expect(state).toEqual({ apiToken: "token", user: undefined @@ -76,7 +79,7 @@ describe('auth-reducer', () => { ownerUuid: "ownerUuid" }; - const state = authReducer(initialState, authActions.USER_DETAILS_SUCCESS(user)); + const state = reducer(initialState, authActions.USER_DETAILS_SUCCESS(user)); expect(state).toEqual({ apiToken: undefined, user: { @@ -94,18 +97,18 @@ describe('auth-reducer', () => { it('should fire external url to login', () => { const initialState = undefined; window.location.assign = jest.fn(); - authReducer(initialState, authActions.LOGIN()); + reducer(initialState, authActions.LOGIN()); expect(window.location.assign).toBeCalledWith( - `${API_HOST}/login?return_to=${window.location.protocol}//${window.location.host}/token` + `/login?return_to=${window.location.protocol}//${window.location.host}/token` ); }); it('should fire external url to logout', () => { const initialState = undefined; window.location.assign = jest.fn(); - authReducer(initialState, authActions.LOGOUT()); + reducer(initialState, authActions.LOGOUT()); expect(window.location.assign).toBeCalledWith( - `${API_HOST}/logout?return_to=${location.protocol}//${location.host}` + `/logout?return_to=${location.protocol}//${location.host}` ); }); });