mirror of
				https://github.com/grafana/grafana.git
				synced 2025-02-25 18:55:37 -06:00 
			
		
		
		
	* Revert "Revert "LibraryPanel: Fallback to panel title if library panel title …"
This reverts commit 6e705ee67c.
* LibraryPanels: Respect model title when adding a library panel to a dashboard
* remove debugger
---------
Co-authored-by: Haris Rozajac <haris.rozajac12@gmail.com>
		
	
		
			
				
	
	
		
			186 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			186 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import { SceneTimeRange, VizPanel } from '@grafana/scenes';
 | |
| import { LibraryPanel } from '@grafana/schema/dist/esm/index.gen';
 | |
| 
 | |
| import { activateFullSceneTree } from '../utils/test-utils';
 | |
| 
 | |
| import { AddLibraryPanelDrawer } from './AddLibraryPanelDrawer';
 | |
| import { DashboardScene } from './DashboardScene';
 | |
| import { LibraryPanelBehavior } from './LibraryPanelBehavior';
 | |
| import { DefaultGridLayoutManager } from './layout-default/DefaultGridLayoutManager';
 | |
| 
 | |
| jest.mock('@grafana/runtime', () => ({
 | |
|   ...jest.requireActual('@grafana/runtime'),
 | |
|   getDataSourceSrv: () => {
 | |
|     return {
 | |
|       get: jest.fn().mockResolvedValue({}),
 | |
|       getInstanceSettings: jest.fn().mockResolvedValue({ uid: 'ds1' }),
 | |
|     };
 | |
|   },
 | |
| }));
 | |
| 
 | |
| describe('AddLibraryPanelWidget', () => {
 | |
|   let dashboard: DashboardScene;
 | |
|   let addLibPanelDrawer: AddLibraryPanelDrawer;
 | |
| 
 | |
|   beforeEach(async () => {
 | |
|     const result = await buildTestScene();
 | |
|     dashboard = result.dashboard;
 | |
|     addLibPanelDrawer = result.drawer;
 | |
|   });
 | |
| 
 | |
|   it('should add library panel from menu', () => {
 | |
|     const panelInfo: LibraryPanel = {
 | |
|       uid: 'uid',
 | |
|       model: {
 | |
|         title: 'model title',
 | |
|         type: 'timeseries',
 | |
|       },
 | |
|       name: 'name',
 | |
|       version: 1,
 | |
|       type: 'timeseries',
 | |
|     };
 | |
| 
 | |
|     addLibPanelDrawer.onAddLibraryPanel(panelInfo);
 | |
| 
 | |
|     const panels = dashboard.state.body.getVizPanels();
 | |
|     const panel = panels[0];
 | |
| 
 | |
|     expect(panels.length).toBe(1);
 | |
|     expect(panel.state.$behaviors![0]).toBeInstanceOf(LibraryPanelBehavior);
 | |
|     expect(panel.state.key).toBe('panel-1');
 | |
|     expect(panel.state.title).toBe('model title');
 | |
|     expect(panel.state.hoverHeader).toBe(false);
 | |
|   });
 | |
| 
 | |
|   it('should add library panel from menu and enter edit mode in a dashboard that is not already in edit mode', async () => {
 | |
|     const drawer = new AddLibraryPanelDrawer({});
 | |
|     const dashboard = new DashboardScene({
 | |
|       $timeRange: new SceneTimeRange({}),
 | |
|       title: 'hello',
 | |
|       uid: 'dash-1',
 | |
|       version: 4,
 | |
|       meta: {
 | |
|         canEdit: true,
 | |
|       },
 | |
|       overlay: drawer,
 | |
|     });
 | |
| 
 | |
|     activateFullSceneTree(dashboard);
 | |
| 
 | |
|     await new Promise((r) => setTimeout(r, 1));
 | |
| 
 | |
|     const panelInfo: LibraryPanel = {
 | |
|       uid: 'uid',
 | |
|       model: {
 | |
|         title: 'model title',
 | |
|         type: 'timeseries',
 | |
|       },
 | |
|       name: 'name',
 | |
|       version: 1,
 | |
|       type: 'timeseries',
 | |
|     };
 | |
| 
 | |
|     // if we are in a saved dashboard with no panels, adding a lib panel through
 | |
|     // the CTA should enter edit mode
 | |
|     expect(dashboard.state.isEditing).toBe(undefined);
 | |
| 
 | |
|     drawer.onAddLibraryPanel(panelInfo);
 | |
| 
 | |
|     const panels = dashboard.state.body.getVizPanels();
 | |
|     const panel = panels[0];
 | |
| 
 | |
|     expect(panels.length).toBe(1);
 | |
|     expect(panel.state.$behaviors![0]).toBeInstanceOf(LibraryPanelBehavior);
 | |
|     expect(panel.state.key).toBe('panel-1');
 | |
|     expect(panel.state.title).toBe('model title');
 | |
|     expect(dashboard.state.isEditing).toBe(true);
 | |
|   });
 | |
| 
 | |
|   it('should replace grid item when grid item state is passed', async () => {
 | |
|     const libPanel = new VizPanel({
 | |
|       title: 'Some panel title',
 | |
|       pluginId: 'table',
 | |
|       key: 'panel-1',
 | |
|       $behaviors: [new LibraryPanelBehavior({ name: 'LibraryPanel A', uid: 'uid' })],
 | |
|     });
 | |
| 
 | |
|     addLibPanelDrawer = new AddLibraryPanelDrawer({ panelToReplaceRef: libPanel.getRef() });
 | |
|     dashboard = new DashboardScene({
 | |
|       $timeRange: new SceneTimeRange({}),
 | |
|       title: 'hello',
 | |
|       uid: 'dash-1',
 | |
|       version: 4,
 | |
|       meta: {
 | |
|         canEdit: true,
 | |
|       },
 | |
|       body: DefaultGridLayoutManager.fromVizPanels([libPanel]),
 | |
|       overlay: addLibPanelDrawer,
 | |
|     });
 | |
| 
 | |
|     const panelInfo: LibraryPanel = {
 | |
|       uid: 'new_uid',
 | |
|       model: {
 | |
|         title: 'model title',
 | |
|         type: 'timeseries',
 | |
|       },
 | |
|       name: 'new_name',
 | |
|       version: 1,
 | |
|       type: 'timeseries',
 | |
|     };
 | |
| 
 | |
|     addLibPanelDrawer.onAddLibraryPanel(panelInfo);
 | |
| 
 | |
|     const panels = dashboard.state.body.getVizPanels();
 | |
|     expect(panels.length).toBe(1);
 | |
| 
 | |
|     const behavior = panels[0].state.$behaviors![0] as LibraryPanelBehavior;
 | |
| 
 | |
|     expect(behavior).toBeInstanceOf(LibraryPanelBehavior);
 | |
|     expect(behavior.state.uid).toBe('new_uid');
 | |
|     expect(behavior.state.name).toBe('new_name');
 | |
|     expect(panels[0].state.title).toBe('model title');
 | |
|   });
 | |
| 
 | |
|   it('should set hoverHeader to true if the library panel title is empty', () => {
 | |
|     const panelInfo: LibraryPanel = {
 | |
|       uid: 'uid',
 | |
|       model: {
 | |
|         title: '',
 | |
|         type: 'timeseries',
 | |
|       },
 | |
|       name: 'name',
 | |
|       version: 1,
 | |
|       type: 'timeseries',
 | |
|     };
 | |
| 
 | |
|     addLibPanelDrawer.onAddLibraryPanel(panelInfo);
 | |
| 
 | |
|     const panels = dashboard.state.body.getVizPanels();
 | |
|     const panel = panels[0];
 | |
|     expect(panel.state.title).toBe('');
 | |
|     expect(panel.state.hoverHeader).toBe(true);
 | |
|   });
 | |
| });
 | |
| 
 | |
| async function buildTestScene() {
 | |
|   const drawer = new AddLibraryPanelDrawer({});
 | |
|   const dashboard = new DashboardScene({
 | |
|     $timeRange: new SceneTimeRange({}),
 | |
|     title: 'hello',
 | |
|     uid: 'dash-1',
 | |
|     version: 4,
 | |
|     meta: {
 | |
|       canEdit: true,
 | |
|     },
 | |
|     overlay: drawer,
 | |
|   });
 | |
| 
 | |
|   activateFullSceneTree(dashboard);
 | |
| 
 | |
|   await new Promise((r) => setTimeout(r, 1));
 | |
| 
 | |
|   dashboard.onEnterEditMode();
 | |
| 
 | |
|   return { dashboard, drawer };
 | |
| }
 |