mirror of
https://github.com/grafana/grafana.git
synced 2025-02-15 10:03:33 -06:00
* Eslint: no-duplicate-imports rule (bump grafana-eslint-config) * Chore: Fix duplicate imports (#31041) * Rebased this branch into eslint-no-duplicate-imports * updated some changes * merged uncaught duplicate imports * fixes frontend test- I hope * fixes e2e test- I hope Co-authored-by: Uchechukwu Obasi <obasiuche62@gmail.com>
86 lines
2.4 KiB
TypeScript
86 lines
2.4 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);
|
|
});
|
|
|
|
it('should create panel state', async () => {
|
|
expect(state.panels['1']).toBeDefined();
|
|
expect(state.panels['2']).toBeDefined();
|
|
});
|
|
});
|
|
|
|
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);
|
|
});
|
|
});
|
|
});
|