mirror of
https://github.com/grafana/grafana.git
synced 2025-02-15 01:53:33 -06:00
* Add and configure eslint-plugin-import * Fix the lint:ts npm command * Autofix + prettier all the files * Manually fix remaining files * Move jquery code in jest-setup to external file to safely reorder imports * Resolve issue caused by circular dependencies within Prometheus * Update .betterer.results * Fix missing // @ts-ignore * ignore iconBundle.ts * Fix missing // @ts-ignore
72 lines
2.0 KiB
TypeScript
72 lines
2.0 KiB
TypeScript
import { DashboardInitPhase, DashboardState, OrgRole, PermissionLevel } from 'app/types';
|
|
|
|
import { DashboardModel } from './DashboardModel';
|
|
import {
|
|
dashboardInitCompleted,
|
|
dashboardInitFailed,
|
|
dashboardInitFetching,
|
|
loadDashboardPermissions,
|
|
dashboardReducer,
|
|
initialState,
|
|
} from './reducers';
|
|
|
|
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,
|
|
dashboardInitCompleted(
|
|
new DashboardModel({
|
|
title: 'My dashboard',
|
|
panels: [{ id: 1 }, { id: 2 }],
|
|
})
|
|
)
|
|
);
|
|
});
|
|
|
|
it('should set model', async () => {
|
|
expect(state.getModel()!.title).toBe('My dashboard');
|
|
});
|
|
});
|
|
|
|
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 initError', async () => {
|
|
expect(state.initError?.message).toBe('Oh no');
|
|
});
|
|
|
|
it('should set phase failed', async () => {
|
|
expect(state.initPhase).toBe(DashboardInitPhase.Failed);
|
|
});
|
|
});
|
|
});
|