Plugins Catalog: use createAction() instead of string action type (#40393)

* refactor(Plugins/Admin): use createAction() instead of string action type

* refactor(Panel/Actions): use the new action name in the tests
This commit is contained in:
Levente Balogh
2021-10-14 08:35:04 +02:00
committed by GitHub
parent 51c5afe840
commit 6e395c8275
3 changed files with 10 additions and 9 deletions

View File

@@ -3,6 +3,7 @@ import { thunkTester } from '../../../../test/core/thunk/thunkTester';
import { changePanelPlugin } from './actions'; import { changePanelPlugin } from './actions';
import { panelModelAndPluginReady } from './reducers'; import { panelModelAndPluginReady } from './reducers';
import { getPanelPlugin } from 'app/features/plugins/__mocks__/pluginMocks'; import { getPanelPlugin } from 'app/features/plugins/__mocks__/pluginMocks';
import { panelPluginLoaded } from 'app/features/plugins/admin/state/actions';
jest.mock('app/features/plugins/importPanelPlugin', () => { jest.mock('app/features/plugins/importPanelPlugin', () => {
return { return {
@@ -31,7 +32,7 @@ describe('panel state actions', () => {
.whenThunkIsDispatched(sourcePanel, 'table'); .whenThunkIsDispatched(sourcePanel, 'table');
expect(dispatchedActions.length).toBe(2); expect(dispatchedActions.length).toBe(2);
expect(dispatchedActions[0].type).toBe('plugins/loadPanelPlugin/fulfilled'); expect(dispatchedActions[0].type).toBe(panelPluginLoaded.type);
expect(dispatchedActions[1].type).toBe(panelModelAndPluginReady.type); expect(dispatchedActions[1].type).toBe(panelModelAndPluginReady.type);
expect(sourcePanel.type).toBe('table'); expect(sourcePanel.type).toBe('table');
}); });

View File

@@ -1,4 +1,4 @@
import { createAsyncThunk, Update } from '@reduxjs/toolkit'; import { createAction, createAsyncThunk, Update } from '@reduxjs/toolkit';
import { getBackendSrv } from '@grafana/runtime'; import { getBackendSrv } from '@grafana/runtime';
import { PanelPlugin } from '@grafana/data'; import { PanelPlugin } from '@grafana/data';
import { StoreState, ThunkResult } from 'app/types'; import { StoreState, ThunkResult } from 'app/types';
@@ -96,6 +96,8 @@ export const loadPluginDashboards = createAsyncThunk(`${STATE_PREFIX}/loadPlugin
return getBackendSrv().get(url); return getBackendSrv().get(url);
}); });
export const panelPluginLoaded = createAction<PanelPlugin>(`${STATE_PREFIX}/panelPluginLoaded`);
// We need this to be backwards-compatible with other parts of Grafana. // We need this to be backwards-compatible with other parts of Grafana.
// (Originally in "public/app/features/plugins/state/actions.ts") // (Originally in "public/app/features/plugins/state/actions.ts")
// It cannot be constructed with `createAsyncThunk()` as we need the return value on the call-site, // It cannot be constructed with `createAsyncThunk()` as we need the return value on the call-site,
@@ -110,10 +112,7 @@ export const loadPanelPlugin = (id: string): ThunkResult<Promise<PanelPlugin>> =
// second check to protect against raise condition // second check to protect against raise condition
if (!getStore().plugins.panels[id]) { if (!getStore().plugins.panels[id]) {
dispatch({ dispatch(panelPluginLoaded(plugin));
type: `${STATE_PREFIX}/loadPanelPlugin/fulfilled`,
payload: plugin,
});
} }
} }

View File

@@ -1,7 +1,8 @@
import { createSlice, createEntityAdapter, AnyAction, PayloadAction } from '@reduxjs/toolkit'; import { createSlice, createEntityAdapter, AnyAction, PayloadAction } from '@reduxjs/toolkit';
import { fetchAll, fetchDetails, install, uninstall, loadPluginDashboards } from './actions'; import { fetchAll, fetchDetails, install, uninstall, loadPluginDashboards, panelPluginLoaded } from './actions';
import { CatalogPlugin, PluginListDisplayMode, ReducerState, RequestStatus } from '../types'; import { CatalogPlugin, PluginListDisplayMode, ReducerState, RequestStatus } from '../types';
import { STATE_PREFIX } from '../constants'; import { STATE_PREFIX } from '../constants';
import { PanelPlugin } from '@grafana/data';
export const pluginsAdapter = createEntityAdapter<CatalogPlugin>(); export const pluginsAdapter = createEntityAdapter<CatalogPlugin>();
@@ -62,8 +63,8 @@ const slice = createSlice({
}) })
// Load a panel plugin (backward-compatibility) // Load a panel plugin (backward-compatibility)
// TODO<remove once the "plugin_admin_enabled" feature flag is removed> // TODO<remove once the "plugin_admin_enabled" feature flag is removed>
.addCase(`${STATE_PREFIX}/loadPanelPlugin/fulfilled`, (state, action: AnyAction) => { .addCase(panelPluginLoaded, (state, action: PayloadAction<PanelPlugin>) => {
state.panels[action.payload.meta!.id] = action.payload; state.panels[action.payload.meta.id] = action.payload;
}) })
// Start loading panel dashboards (backward-compatibility) // Start loading panel dashboards (backward-compatibility)
// TODO<remove once the "plugin_admin_enabled" feature flag is removed> // TODO<remove once the "plugin_admin_enabled" feature flag is removed>