1
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

35 lines
1.2 KiB

import { reducerTester } from '../../../../../test/core/redux/reducerTester';
import {
deleteLibraryPanelModalReducer,
DeleteLibraryPanelModalState,
initialDeleteLibraryPanelModalState,
searchCompleted,
} from './reducer';
import { LoadingState } from '@grafana/data';
describe('deleteLibraryPanelModalReducer', () => {
describe('when created', () => {
it('then initial state should be correct', () => {
reducerTester<DeleteLibraryPanelModalState>()
.givenReducer(deleteLibraryPanelModalReducer, initialDeleteLibraryPanelModalState)
.whenActionIsDispatched({ type: 'noop' })
.thenStateShouldEqual({
loadingState: LoadingState.Loading,
dashboardTitles: [],
});
});
});
describe('when searchCompleted is dispatched', () => {
it('then state should be correct', () => {
const dashboards: any[] = [{ title: 'A' }, { title: 'B' }];
reducerTester<DeleteLibraryPanelModalState>()
.givenReducer(deleteLibraryPanelModalReducer, initialDeleteLibraryPanelModalState)
.whenActionIsDispatched(searchCompleted({ dashboards }))
.thenStateShouldEqual({
loadingState: LoadingState.Done,
dashboardTitles: ['A', 'B'],
});
});
});
});