mirror of
https://github.com/grafana/grafana.git
synced 2025-02-16 02:23:31 -06:00
* Refactor: Adds Redux Toolkit package * Refactor: Uses configureStore from Redux Toolkit * Refactor: Migrates applicationReducer * Refactor: Migrates appNotificationsReducer * Refactor: Migrates locationReducer * Refactor: Migrates navModelReducer * Refactor: Migrates teamsReducer and teamReducer * Refactor: Migrates cleanUpAction * Refactor: Migrates alertRulesReducer * Refactor: Cleans up recursiveCleanState * Refactor: Switched to Angular compatible reducers * Refactor: Migrates folderReducer * Refactor: Migrates dashboardReducer * Migrates panelEditorReducer * Refactor: Migrates dataSourcesReducer * Refactor: Migrates usersReducer * Refactor: Migrates organizationReducer * Refactor: Migrates pluginsReducer * Refactor: Migrates ldapReducer and ldapUserReducer * Refactor: Migrates apiKeysReducer * Refactor: Migrates exploreReducer and itemReducer * Refactor: Removes actionCreatorFactory and reducerFactory * Refactor: Moves mocks to test section * Docs: Removes sections about home grown framework * Update contribute/style-guides/redux.md Co-Authored-By: Diana Payton <52059945+oddlittlebird@users.noreply.github.com> * Refactor: Cleans up some code * Refactor: Adds state typings * Refactor: Cleans up typings * Refactor: Adds comment about ImmerJs autoFreeze Co-authored-by: Diana Payton <52059945+oddlittlebird@users.noreply.github.com>
155 lines
5.9 KiB
TypeScript
155 lines
5.9 KiB
TypeScript
import { reducerTester } from '../../../test/core/redux/reducerTester';
|
|
import { initialState, locationReducer, updateLocation } from './location';
|
|
import { LocationState } from '../../types';
|
|
|
|
describe('locationReducer', () => {
|
|
describe('when updateLocation is dispatched', () => {
|
|
it('then state should be correct', () => {
|
|
reducerTester<LocationState>()
|
|
.givenReducer(locationReducer, { ...initialState, query: { queryParam: 3, queryParam2: 2 } })
|
|
.whenActionIsDispatched(
|
|
updateLocation({
|
|
query: { queryParam: 1 },
|
|
partial: false,
|
|
path: '/api/dashboard',
|
|
replace: false,
|
|
routeParams: { routeParam: 2 },
|
|
})
|
|
)
|
|
.thenStatePredicateShouldEqual(resultingState => {
|
|
expect(resultingState.path).toEqual('/api/dashboard');
|
|
expect(resultingState.url).toEqual('/api/dashboard?queryParam=1');
|
|
expect(resultingState.query).toEqual({ queryParam: 1 });
|
|
expect(resultingState.routeParams).toEqual({ routeParam: 2 });
|
|
expect(resultingState.replace).toEqual(false);
|
|
return true;
|
|
});
|
|
});
|
|
});
|
|
|
|
describe('when updateLocation is dispatched with replace', () => {
|
|
it('then state should be correct', () => {
|
|
reducerTester<LocationState>()
|
|
.givenReducer(locationReducer, { ...initialState, query: { queryParam: 3, queryParam2: 2 } })
|
|
.whenActionIsDispatched(
|
|
updateLocation({
|
|
query: { queryParam: 1 },
|
|
partial: false,
|
|
path: '/api/dashboard',
|
|
replace: true,
|
|
routeParams: { routeParam: 2 },
|
|
})
|
|
)
|
|
.thenStatePredicateShouldEqual(resultingState => {
|
|
expect(resultingState.path).toEqual('/api/dashboard');
|
|
expect(resultingState.url).toEqual('/api/dashboard?queryParam=1');
|
|
expect(resultingState.query).toEqual({ queryParam: 1 });
|
|
expect(resultingState.routeParams).toEqual({ routeParam: 2 });
|
|
expect(resultingState.replace).toEqual(true);
|
|
return true;
|
|
});
|
|
});
|
|
});
|
|
|
|
describe('when updateLocation is dispatched with partial', () => {
|
|
it('then state should be correct', () => {
|
|
reducerTester<LocationState>()
|
|
.givenReducer(locationReducer, { ...initialState, query: { queryParam: 3, queryParam2: 2 } })
|
|
.whenActionIsDispatched(
|
|
updateLocation({
|
|
query: { queryParam: 1 },
|
|
partial: true,
|
|
path: '/api/dashboard',
|
|
replace: false,
|
|
routeParams: { routeParam: 2 },
|
|
})
|
|
)
|
|
.thenStatePredicateShouldEqual(resultingState => {
|
|
expect(resultingState.path).toEqual('/api/dashboard');
|
|
expect(resultingState.url).toEqual('/api/dashboard?queryParam=1&queryParam2=2');
|
|
expect(resultingState.query).toEqual({ queryParam: 1, queryParam2: 2 });
|
|
expect(resultingState.routeParams).toEqual({ routeParam: 2 });
|
|
expect(resultingState.replace).toEqual(false);
|
|
return true;
|
|
});
|
|
});
|
|
});
|
|
|
|
describe('when updateLocation is dispatched without query', () => {
|
|
it('then state should be correct', () => {
|
|
reducerTester<LocationState>()
|
|
.givenReducer(locationReducer, { ...initialState, query: { queryParam: 3, queryParam2: 2 } })
|
|
.whenActionIsDispatched(
|
|
updateLocation({
|
|
partial: false,
|
|
path: '/api/dashboard',
|
|
replace: false,
|
|
routeParams: { routeParam: 2 },
|
|
})
|
|
)
|
|
.thenStatePredicateShouldEqual(resultingState => {
|
|
expect(resultingState.path).toEqual('/api/dashboard');
|
|
expect(resultingState.url).toEqual('/api/dashboard?queryParam=3&queryParam2=2');
|
|
expect(resultingState.query).toEqual({ queryParam: 3, queryParam2: 2 });
|
|
expect(resultingState.routeParams).toEqual({ routeParam: 2 });
|
|
expect(resultingState.replace).toEqual(false);
|
|
return true;
|
|
});
|
|
});
|
|
});
|
|
|
|
describe('when updateLocation is dispatched without routeParams', () => {
|
|
it('then state should be correct', () => {
|
|
reducerTester<LocationState>()
|
|
.givenReducer(locationReducer, {
|
|
...initialState,
|
|
query: { queryParam: 3, queryParam2: 2 },
|
|
routeParams: { routeStateParam: 4 },
|
|
})
|
|
.whenActionIsDispatched(
|
|
updateLocation({
|
|
query: { queryParam: 1 },
|
|
partial: false,
|
|
path: '/api/dashboard',
|
|
replace: false,
|
|
})
|
|
)
|
|
.thenStatePredicateShouldEqual(resultingState => {
|
|
expect(resultingState.path).toEqual('/api/dashboard');
|
|
expect(resultingState.url).toEqual('/api/dashboard?queryParam=1');
|
|
expect(resultingState.query).toEqual({ queryParam: 1 });
|
|
expect(resultingState.routeParams).toEqual({ routeStateParam: 4 });
|
|
expect(resultingState.replace).toEqual(false);
|
|
return true;
|
|
});
|
|
});
|
|
});
|
|
|
|
describe('when updateLocation is dispatched without path', () => {
|
|
it('then state should be correct', () => {
|
|
reducerTester<LocationState>()
|
|
.givenReducer(locationReducer, {
|
|
...initialState,
|
|
query: { queryParam: 3, queryParam2: 2 },
|
|
path: '/api/state/path',
|
|
})
|
|
.whenActionIsDispatched(
|
|
updateLocation({
|
|
query: { queryParam: 1 },
|
|
partial: false,
|
|
replace: false,
|
|
routeParams: { routeParam: 2 },
|
|
})
|
|
)
|
|
.thenStatePredicateShouldEqual(resultingState => {
|
|
expect(resultingState.path).toEqual('/api/state/path');
|
|
expect(resultingState.url).toEqual('/api/state/path?queryParam=1');
|
|
expect(resultingState.query).toEqual({ queryParam: 1 });
|
|
expect(resultingState.routeParams).toEqual({ routeParam: 2 });
|
|
expect(resultingState.replace).toEqual(false);
|
|
return true;
|
|
});
|
|
});
|
|
});
|
|
});
|