import { createMemoryHistory } from 'history' import { DottedName } from 'modele-social' import { createStore, Store, StoreEnhancer } from 'redux' import { beforeEach, describe, expect, it, vi } from 'vitest' import { setupSimulationPersistence } from '@/storage/persistSimulation' import * as safeLocalStorage from '@/storage/safeLocalStorage' import { enregistreLaRéponse, loadPreviousSimulation, setSimulationConfig, } from '@/store/actions/actions' import reducers, { SimulationConfig } from '@/store/reducers/rootReducer' import { Simulation } from '@/store/reducers/simulation.reducer' function delay(ms: number) { return new Promise((resolve) => setTimeout(resolve, ms)) } const simulationConfig: SimulationConfig = { 'objectifs exclusifs': [], objectifs: [], situation: {}, 'unité par défaut': '€/mois', } const initialSimulation: Simulation = { config: simulationConfig, url: '/someurl', hiddenNotifications: [], situation: {}, targetUnit: '€/mois', answeredQuestions: ['somestep' as DottedName], currentQuestion: null, } describe('[persistence] When simulation persistence is setup', () => { let store: Store const setItemSpy = vi.spyOn(safeLocalStorage, 'setItem') beforeEach(() => { store = createStore(reducers, { simulation: initialSimulation, activeTargetInput: 'sometargetinput', } as unknown as StoreEnhancer) setupSimulationPersistence(store, 0) }) describe('when the state is changed with some data that is persistable', () => { beforeEach(async () => { store.dispatch(enregistreLaRéponse('dotted name' as DottedName, '42')) await delay(0) }) it('saves state in localStorage with all fields', () => { expect(setItemSpy).toHaveBeenCalled() expect(setItemSpy.mock.calls[0]![1]).toBe( '{"situation":{"dotted name":"42"},"activeTargetInput":"sometargetinput","foldedSteps":["somestep"]}' ) }) it('saves state in localStorage with a key dependent on the simulation url', () => { expect(setItemSpy).toHaveBeenCalled() expect(setItemSpy.mock.calls[0]![0]).toContain('someurl') }) }) }) describe('[persistence] When simulation config is set', () => { const serializedPreviousSimulation = '{"situation":{"dotted name . other":"42"},"activeTargetInput":"someothertargetinput","foldedSteps":["someotherstep"]}' let store: Store vi.spyOn(safeLocalStorage, 'getItem').mockReturnValue( serializedPreviousSimulation ) beforeEach(() => { store = createStore(reducers) const history = createMemoryHistory() history.replace('/someotherurl') store.dispatch( setSimulationConfig(simulationConfig, history.location.pathname) ) }) describe('when previous simulation is loaded in state', () => { beforeEach(() => { store.dispatch(loadPreviousSimulation()) }) it('loads url in state', () => { expect(store.getState().simulation.url).toBe('/someotherurl') }) it('loads situation in state', () => { expect(store.getState().simulation.situation).toEqual({ 'dotted name . other': '42', }) }) it('loads activeTargetInput in state', () => { expect(store.getState().activeTargetInput).toBe('someothertargetinput') }) it('loads foldedSteps in state', () => { expect(store.getState().simulation.foldedSteps).toEqual(['someotherstep']) }) }) })