mirror of
https://github.com/grafana/grafana.git
synced 2025-02-12 16:45:43 -06:00
* Initial pass to move panel state to it's own, and make it by key not panel.id * Progress * Not making much progress, having panel.key be mutable is causing a lot of issues * Think this is starting to work * Began fixing tests * Add selector * Bug fixes and changes to cleanup, and fixing all flicking when switching library panels * Removed console.log * fixes after merge * fixing tests * fixing tests * Added new test for changePlugin thunk
81 lines
2.3 KiB
TypeScript
81 lines
2.3 KiB
TypeScript
import {
|
|
dashboardInitCompleted,
|
|
dashboardInitFailed,
|
|
dashboardInitFetching,
|
|
dashboardInitSlow,
|
|
loadDashboardPermissions,
|
|
dashboardReducer,
|
|
initialState,
|
|
} from './reducers';
|
|
import { DashboardInitPhase, DashboardState, OrgRole, PermissionLevel } from 'app/types';
|
|
import { DashboardModel } from './DashboardModel';
|
|
|
|
describe('dashboard reducer', () => {
|
|
describe('loadDashboardPermissions', () => {
|
|
let state: DashboardState;
|
|
|
|
beforeEach(() => {
|
|
const action = loadDashboardPermissions([
|
|
{ id: 2, dashboardId: 1, role: OrgRole.Viewer, permission: PermissionLevel.View },
|
|
{ id: 3, dashboardId: 1, role: OrgRole.Editor, permission: PermissionLevel.Edit },
|
|
]);
|
|
state = dashboardReducer(initialState, action);
|
|
});
|
|
|
|
it('should add permissions to state', async () => {
|
|
expect(state.permissions?.length).toBe(2);
|
|
});
|
|
});
|
|
|
|
describe('dashboardInitCompleted', () => {
|
|
let state: DashboardState;
|
|
|
|
beforeEach(() => {
|
|
state = dashboardReducer(initialState, dashboardInitFetching());
|
|
state = dashboardReducer(state, dashboardInitSlow());
|
|
state = dashboardReducer(
|
|
state,
|
|
dashboardInitCompleted(
|
|
new DashboardModel({
|
|
title: 'My dashboard',
|
|
panels: [{ id: 1 }, { id: 2 }],
|
|
})
|
|
)
|
|
);
|
|
});
|
|
|
|
it('should set model', async () => {
|
|
expect(state.getModel()!.title).toBe('My dashboard');
|
|
});
|
|
|
|
it('should set reset isInitSlow', async () => {
|
|
expect(state.isInitSlow).toBe(false);
|
|
});
|
|
});
|
|
|
|
describe('dashboardInitFailed', () => {
|
|
let state: DashboardState;
|
|
|
|
beforeEach(() => {
|
|
state = dashboardReducer(initialState, dashboardInitFetching());
|
|
state = dashboardReducer(state, dashboardInitFailed({ message: 'Oh no', error: 'sad' }));
|
|
});
|
|
|
|
it('should set model', async () => {
|
|
expect(state.getModel()?.title).toBe('Dashboard init failed');
|
|
});
|
|
|
|
it('should set reset isInitSlow', async () => {
|
|
expect(state.isInitSlow).toBe(false);
|
|
});
|
|
|
|
it('should set initError', async () => {
|
|
expect(state.initError?.message).toBe('Oh no');
|
|
});
|
|
|
|
it('should set phase failed', async () => {
|
|
expect(state.initPhase).toBe(DashboardInitPhase.Failed);
|
|
});
|
|
});
|
|
});
|