| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  | import _ from 'lodash'; | 
					
						
							| 
									
										
										
										
											2019-01-31 08:56:17 +01:00
										 |  |  | import { DashboardModel } from '../state/DashboardModel'; | 
					
						
							|  |  |  | import { PanelModel } from '../state/PanelModel'; | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  | import { GRID_CELL_HEIGHT, GRID_CELL_VMARGIN } from 'app/core/constants'; | 
					
						
							|  |  |  | import { expect } from 'test/lib/common'; | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  | jest.mock('app/core/services/context_srv', () => ({})); | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-04 15:55:41 +02:00
										 |  |  | describe('DashboardModel', () => { | 
					
						
							|  |  |  |   describe('when creating dashboard with old schema', () => { | 
					
						
							| 
									
										
										
										
											2018-08-26 20:19:23 +02:00
										 |  |  |     let model; | 
					
						
							|  |  |  |     let graph; | 
					
						
							|  |  |  |     let singlestat; | 
					
						
							|  |  |  |     let table; | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-04 15:55:41 +02:00
										 |  |  |     beforeEach(() => { | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |       model = new DashboardModel({ | 
					
						
							| 
									
										
										
										
											2017-12-19 16:06:54 +01:00
										 |  |  |         services: { | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |           filter: { time: { from: 'now-1d', to: 'now' }, list: [{}] }, | 
					
						
							| 
									
										
										
										
											2017-12-19 16:06:54 +01:00
										 |  |  |         }, | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |         pulldowns: [ | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |           { type: 'filtering', enable: true }, | 
					
						
							|  |  |  |           { type: 'annotations', enable: true, annotations: [{ name: 'old' }] }, | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |         ], | 
					
						
							|  |  |  |         panels: [ | 
					
						
							|  |  |  |           { | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |             type: 'graph', | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |             legend: true, | 
					
						
							|  |  |  |             aliasYAxis: { test: 2 }, | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |             y_formats: ['kbyte', 'ms'], | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |             grid: { | 
					
						
							|  |  |  |               min: 1, | 
					
						
							|  |  |  |               max: 10, | 
					
						
							|  |  |  |               rightMin: 5, | 
					
						
							|  |  |  |               rightMax: 15, | 
					
						
							|  |  |  |               leftLogBase: 1, | 
					
						
							|  |  |  |               rightLogBase: 2, | 
					
						
							|  |  |  |               threshold1: 200, | 
					
						
							|  |  |  |               threshold2: 400, | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |               threshold1Color: 'yellow', | 
					
						
							|  |  |  |               threshold2Color: 'red', | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |             }, | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |             leftYAxisLabel: 'left label', | 
					
						
							|  |  |  |             targets: [{ refId: 'A' }, {}], | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |           }, | 
					
						
							|  |  |  |           { | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |             type: 'singlestat', | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |             legend: true, | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |             thresholds: '10,20,30', | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |             aliasYAxis: { test: 2 }, | 
					
						
							|  |  |  |             grid: { min: 1, max: 10 }, | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |             targets: [{ refId: 'A' }, {}], | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |           }, | 
					
						
							|  |  |  |           { | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |             type: 'table', | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |             legend: true, | 
					
						
							| 
									
										
										
										
											2017-12-21 08:39:31 +01:00
										 |  |  |             styles: [{ thresholds: ['10', '20', '30'] }, { thresholds: ['100', '200', '300'] }], | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |             targets: [{ refId: 'A' }, {}], | 
					
						
							|  |  |  |           }, | 
					
						
							|  |  |  |         ], | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |       }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       graph = model.panels[0]; | 
					
						
							|  |  |  |       singlestat = model.panels[1]; | 
					
						
							|  |  |  |       table = model.panels[2]; | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-04 15:55:41 +02:00
										 |  |  |     it('should have title', () => { | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |       expect(model.title).toBe('No Title'); | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-04 15:55:41 +02:00
										 |  |  |     it('should have panel id', () => { | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |       expect(graph.id).toBe(1); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-04 15:55:41 +02:00
										 |  |  |     it('should move time and filtering list', () => { | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |       expect(model.time.from).toBe('now-1d'); | 
					
						
							|  |  |  |       expect(model.templating.list[0].allFormat).toBe('glob'); | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-04 15:55:41 +02:00
										 |  |  |     it('graphite panel should change name too graph', () => { | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |       expect(graph.type).toBe('graph'); | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-04 15:55:41 +02:00
										 |  |  |     it('single stat panel should have two thresholds', () => { | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |       expect(singlestat.thresholds).toBe('20,30'); | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-04 15:55:41 +02:00
										 |  |  |     it('queries without refId should get it', () => { | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |       expect(graph.targets[1].refId).toBe('B'); | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-04 15:55:41 +02:00
										 |  |  |     it('update legend setting', () => { | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |       expect(graph.legend.show).toBe(true); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-04 15:55:41 +02:00
										 |  |  |     it('move aliasYAxis to series override', () => { | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |       expect(graph.seriesOverrides[0].alias).toBe('test'); | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |       expect(graph.seriesOverrides[0].yaxis).toBe(2); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-04 15:55:41 +02:00
										 |  |  |     it('should move pulldowns to new schema', () => { | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |       expect(model.annotations.list[1].name).toBe('old'); | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-04 15:55:41 +02:00
										 |  |  |     it('table panel should only have two thresholds values', () => { | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |       expect(table.styles[0].thresholds[0]).toBe('20'); | 
					
						
							|  |  |  |       expect(table.styles[0].thresholds[1]).toBe('30'); | 
					
						
							|  |  |  |       expect(table.styles[1].thresholds[0]).toBe('200'); | 
					
						
							|  |  |  |       expect(table.styles[1].thresholds[1]).toBe('300'); | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-04 15:55:41 +02:00
										 |  |  |     it('graph grid to yaxes options', () => { | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |       expect(graph.yaxes[0].min).toBe(1); | 
					
						
							|  |  |  |       expect(graph.yaxes[0].max).toBe(10); | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |       expect(graph.yaxes[0].format).toBe('kbyte'); | 
					
						
							|  |  |  |       expect(graph.yaxes[0].label).toBe('left label'); | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |       expect(graph.yaxes[0].logBase).toBe(1); | 
					
						
							|  |  |  |       expect(graph.yaxes[1].min).toBe(5); | 
					
						
							|  |  |  |       expect(graph.yaxes[1].max).toBe(15); | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |       expect(graph.yaxes[1].format).toBe('ms'); | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |       expect(graph.yaxes[1].logBase).toBe(2); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       expect(graph.grid.rightMax).toBe(undefined); | 
					
						
							|  |  |  |       expect(graph.grid.rightLogBase).toBe(undefined); | 
					
						
							|  |  |  |       expect(graph.y_formats).toBe(undefined); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-04 15:55:41 +02:00
										 |  |  |     it('dashboard schema version should be set to latest', () => { | 
					
						
							| 
									
										
										
										
											2019-02-18 11:41:14 +01:00
										 |  |  |       expect(model.schemaVersion).toBe(18); | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-04 15:55:41 +02:00
										 |  |  |     it('graph thresholds should be migrated', () => { | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |       expect(graph.thresholds.length).toBe(2); | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |       expect(graph.thresholds[0].op).toBe('gt'); | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |       expect(graph.thresholds[0].value).toBe(200); | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |       expect(graph.thresholds[0].fillColor).toBe('yellow'); | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |       expect(graph.thresholds[1].value).toBe(400); | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |       expect(graph.thresholds[1].fillColor).toBe('red'); | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |     }); | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-04 15:55:41 +02:00
										 |  |  |   describe('when migrating to the grid layout', () => { | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |     let model; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-04 15:55:41 +02:00
										 |  |  |     beforeEach(() => { | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |       model = { | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |         rows: [], | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |       }; | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-04 15:55:41 +02:00
										 |  |  |     it('should create proper grid', () => { | 
					
						
							| 
									
										
										
										
											2017-12-19 16:06:54 +01:00
										 |  |  |       model.rows = [createRow({ collapse: false, height: 8 }, [[6], [6]])]; | 
					
						
							| 
									
										
										
										
											2018-08-26 17:14:40 +02:00
										 |  |  |       const dashboard = new DashboardModel(model); | 
					
						
							|  |  |  |       const panelGridPos = getGridPositions(dashboard); | 
					
						
							|  |  |  |       const expectedGrid = [{ x: 0, y: 0, w: 12, h: 8 }, { x: 12, y: 0, w: 12, h: 8 }]; | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  |       expect(panelGridPos).toEqual(expectedGrid); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-04 15:55:41 +02:00
										 |  |  |     it('should add special "row" panel if row is collapsed', () => { | 
					
						
							| 
									
										
										
										
											2017-12-21 08:39:31 +01:00
										 |  |  |       model.rows = [createRow({ collapse: true, height: 8 }, [[6], [6]]), createRow({ height: 8 }, [[12]])]; | 
					
						
							| 
									
										
										
										
											2018-08-26 17:14:40 +02:00
										 |  |  |       const dashboard = new DashboardModel(model); | 
					
						
							|  |  |  |       const panelGridPos = getGridPositions(dashboard); | 
					
						
							|  |  |  |       const expectedGrid = [ | 
					
						
							| 
									
										
										
										
											2017-12-19 16:06:54 +01:00
										 |  |  |         { x: 0, y: 0, w: 24, h: 8 }, // row
 | 
					
						
							|  |  |  |         { x: 0, y: 1, w: 24, h: 8 }, // row
 | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |         { x: 0, y: 2, w: 24, h: 8 }, | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |       ]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       expect(panelGridPos).toEqual(expectedGrid); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-04 15:55:41 +02:00
										 |  |  |     it('should add special "row" panel if row has visible title', () => { | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |       model.rows = [ | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |         createRow({ showTitle: true, title: 'Row', height: 8 }, [[6], [6]]), | 
					
						
							|  |  |  |         createRow({ height: 8 }, [[12]]), | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |       ]; | 
					
						
							| 
									
										
										
										
											2018-08-26 17:14:40 +02:00
										 |  |  |       const dashboard = new DashboardModel(model); | 
					
						
							|  |  |  |       const panelGridPos = getGridPositions(dashboard); | 
					
						
							|  |  |  |       const expectedGrid = [ | 
					
						
							| 
									
										
										
										
											2017-12-19 16:06:54 +01:00
										 |  |  |         { x: 0, y: 0, w: 24, h: 8 }, // row
 | 
					
						
							|  |  |  |         { x: 0, y: 1, w: 12, h: 8 }, | 
					
						
							|  |  |  |         { x: 12, y: 1, w: 12, h: 8 }, | 
					
						
							|  |  |  |         { x: 0, y: 9, w: 24, h: 8 }, // row
 | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |         { x: 0, y: 10, w: 24, h: 8 }, | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |       ]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       expect(panelGridPos).toEqual(expectedGrid); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-04 15:55:41 +02:00
										 |  |  |     it('should not add "row" panel if row has not visible title or not collapsed', () => { | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |       model.rows = [ | 
					
						
							| 
									
										
										
										
											2017-12-19 16:06:54 +01:00
										 |  |  |         createRow({ collapse: true, height: 8 }, [[12]]), | 
					
						
							|  |  |  |         createRow({ height: 8 }, [[12]]), | 
					
						
							|  |  |  |         createRow({ height: 8 }, [[12], [6], [6]]), | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |         createRow({ collapse: true, height: 8 }, [[12]]), | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |       ]; | 
					
						
							| 
									
										
										
										
											2018-08-26 17:14:40 +02:00
										 |  |  |       const dashboard = new DashboardModel(model); | 
					
						
							|  |  |  |       const panelGridPos = getGridPositions(dashboard); | 
					
						
							|  |  |  |       const expectedGrid = [ | 
					
						
							| 
									
										
										
										
											2017-12-19 16:06:54 +01:00
										 |  |  |         { x: 0, y: 0, w: 24, h: 8 }, // row
 | 
					
						
							|  |  |  |         { x: 0, y: 1, w: 24, h: 8 }, // row
 | 
					
						
							|  |  |  |         { x: 0, y: 2, w: 24, h: 8 }, | 
					
						
							|  |  |  |         { x: 0, y: 10, w: 24, h: 8 }, // row
 | 
					
						
							|  |  |  |         { x: 0, y: 11, w: 24, h: 8 }, | 
					
						
							|  |  |  |         { x: 0, y: 19, w: 12, h: 8 }, | 
					
						
							|  |  |  |         { x: 12, y: 19, w: 12, h: 8 }, | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |         { x: 0, y: 27, w: 24, h: 8 }, // row
 | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |       ]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       expect(panelGridPos).toEqual(expectedGrid); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-04 15:55:41 +02:00
										 |  |  |     it('should add all rows if even one collapsed or titled row is present', () => { | 
					
						
							| 
									
										
										
										
											2017-12-21 08:39:31 +01:00
										 |  |  |       model.rows = [createRow({ collapse: true, height: 8 }, [[6], [6]]), createRow({ height: 8 }, [[12]])]; | 
					
						
							| 
									
										
										
										
											2018-08-26 17:14:40 +02:00
										 |  |  |       const dashboard = new DashboardModel(model); | 
					
						
							|  |  |  |       const panelGridPos = getGridPositions(dashboard); | 
					
						
							|  |  |  |       const expectedGrid = [ | 
					
						
							| 
									
										
										
										
											2017-12-19 16:06:54 +01:00
										 |  |  |         { x: 0, y: 0, w: 24, h: 8 }, // row
 | 
					
						
							|  |  |  |         { x: 0, y: 1, w: 24, h: 8 }, // row
 | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |         { x: 0, y: 2, w: 24, h: 8 }, | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |       ]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       expect(panelGridPos).toEqual(expectedGrid); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-04 15:55:41 +02:00
										 |  |  |     it('should properly place panels with fixed height', () => { | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |       model.rows = [ | 
					
						
							| 
									
										
										
										
											2017-12-19 16:06:54 +01:00
										 |  |  |         createRow({ height: 6 }, [[6], [6, 3], [6, 3]]), | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |         createRow({ height: 6 }, [[4], [4], [4, 3], [4, 3]]), | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |       ]; | 
					
						
							| 
									
										
										
										
											2018-08-26 17:14:40 +02:00
										 |  |  |       const dashboard = new DashboardModel(model); | 
					
						
							|  |  |  |       const panelGridPos = getGridPositions(dashboard); | 
					
						
							|  |  |  |       const expectedGrid = [ | 
					
						
							| 
									
										
										
										
											2017-12-19 16:06:54 +01:00
										 |  |  |         { x: 0, y: 0, w: 12, h: 6 }, | 
					
						
							|  |  |  |         { x: 12, y: 0, w: 12, h: 3 }, | 
					
						
							|  |  |  |         { x: 12, y: 3, w: 12, h: 3 }, | 
					
						
							|  |  |  |         { x: 0, y: 6, w: 8, h: 6 }, | 
					
						
							|  |  |  |         { x: 8, y: 6, w: 8, h: 6 }, | 
					
						
							|  |  |  |         { x: 16, y: 6, w: 8, h: 3 }, | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |         { x: 16, y: 9, w: 8, h: 3 }, | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |       ]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       expect(panelGridPos).toEqual(expectedGrid); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-04 15:55:41 +02:00
										 |  |  |     it('should place panel to the right side of panel having bigger height', () => { | 
					
						
							| 
									
										
										
										
											2017-12-21 08:39:31 +01:00
										 |  |  |       model.rows = [createRow({ height: 6 }, [[4], [2, 3], [4, 6], [2, 3], [2, 3]])]; | 
					
						
							| 
									
										
										
										
											2018-08-26 17:14:40 +02:00
										 |  |  |       const dashboard = new DashboardModel(model); | 
					
						
							|  |  |  |       const panelGridPos = getGridPositions(dashboard); | 
					
						
							|  |  |  |       const expectedGrid = [ | 
					
						
							| 
									
										
										
										
											2017-12-19 16:06:54 +01:00
										 |  |  |         { x: 0, y: 0, w: 8, h: 6 }, | 
					
						
							|  |  |  |         { x: 8, y: 0, w: 4, h: 3 }, | 
					
						
							|  |  |  |         { x: 12, y: 0, w: 8, h: 6 }, | 
					
						
							|  |  |  |         { x: 20, y: 0, w: 4, h: 3 }, | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |         { x: 20, y: 3, w: 4, h: 3 }, | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |       ]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       expect(panelGridPos).toEqual(expectedGrid); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-04 15:55:41 +02:00
										 |  |  |     it('should fill current row if it possible', () => { | 
					
						
							| 
									
										
										
										
											2017-12-21 08:39:31 +01:00
										 |  |  |       model.rows = [createRow({ height: 9 }, [[4], [2, 3], [4, 6], [2, 3], [2, 3], [8, 3]])]; | 
					
						
							| 
									
										
										
										
											2018-08-26 17:14:40 +02:00
										 |  |  |       const dashboard = new DashboardModel(model); | 
					
						
							|  |  |  |       const panelGridPos = getGridPositions(dashboard); | 
					
						
							|  |  |  |       const expectedGrid = [ | 
					
						
							| 
									
										
										
										
											2017-12-19 16:06:54 +01:00
										 |  |  |         { x: 0, y: 0, w: 8, h: 9 }, | 
					
						
							|  |  |  |         { x: 8, y: 0, w: 4, h: 3 }, | 
					
						
							|  |  |  |         { x: 12, y: 0, w: 8, h: 6 }, | 
					
						
							|  |  |  |         { x: 20, y: 0, w: 4, h: 3 }, | 
					
						
							|  |  |  |         { x: 20, y: 3, w: 4, h: 3 }, | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |         { x: 8, y: 6, w: 16, h: 3 }, | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |       ]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       expect(panelGridPos).toEqual(expectedGrid); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-04 15:55:41 +02:00
										 |  |  |     it('should fill current row if it possible (2)', () => { | 
					
						
							| 
									
										
										
										
											2017-12-21 08:39:31 +01:00
										 |  |  |       model.rows = [createRow({ height: 8 }, [[4], [2, 3], [4, 6], [2, 3], [2, 3], [8, 3]])]; | 
					
						
							| 
									
										
										
										
											2018-08-26 17:14:40 +02:00
										 |  |  |       const dashboard = new DashboardModel(model); | 
					
						
							|  |  |  |       const panelGridPos = getGridPositions(dashboard); | 
					
						
							|  |  |  |       const expectedGrid = [ | 
					
						
							| 
									
										
										
										
											2017-12-19 16:06:54 +01:00
										 |  |  |         { x: 0, y: 0, w: 8, h: 8 }, | 
					
						
							|  |  |  |         { x: 8, y: 0, w: 4, h: 3 }, | 
					
						
							|  |  |  |         { x: 12, y: 0, w: 8, h: 6 }, | 
					
						
							|  |  |  |         { x: 20, y: 0, w: 4, h: 3 }, | 
					
						
							|  |  |  |         { x: 20, y: 3, w: 4, h: 3 }, | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |         { x: 8, y: 6, w: 16, h: 3 }, | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |       ]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       expect(panelGridPos).toEqual(expectedGrid); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-04 15:55:41 +02:00
										 |  |  |     it('should fill current row if panel height more than row height', () => { | 
					
						
							| 
									
										
										
										
											2017-12-21 08:39:31 +01:00
										 |  |  |       model.rows = [createRow({ height: 6 }, [[4], [2, 3], [4, 8], [2, 3], [2, 3]])]; | 
					
						
							| 
									
										
										
										
											2018-08-26 17:14:40 +02:00
										 |  |  |       const dashboard = new DashboardModel(model); | 
					
						
							|  |  |  |       const panelGridPos = getGridPositions(dashboard); | 
					
						
							|  |  |  |       const expectedGrid = [ | 
					
						
							| 
									
										
										
										
											2017-12-19 16:06:54 +01:00
										 |  |  |         { x: 0, y: 0, w: 8, h: 6 }, | 
					
						
							|  |  |  |         { x: 8, y: 0, w: 4, h: 3 }, | 
					
						
							|  |  |  |         { x: 12, y: 0, w: 8, h: 8 }, | 
					
						
							|  |  |  |         { x: 20, y: 0, w: 4, h: 3 }, | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |         { x: 20, y: 3, w: 4, h: 3 }, | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |       ]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       expect(panelGridPos).toEqual(expectedGrid); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-04 15:55:41 +02:00
										 |  |  |     it('should wrap panels to multiple rows', () => { | 
					
						
							| 
									
										
										
										
											2017-12-19 16:06:54 +01:00
										 |  |  |       model.rows = [createRow({ height: 6 }, [[6], [6], [12], [6], [3], [3]])]; | 
					
						
							| 
									
										
										
										
											2018-08-26 17:14:40 +02:00
										 |  |  |       const dashboard = new DashboardModel(model); | 
					
						
							|  |  |  |       const panelGridPos = getGridPositions(dashboard); | 
					
						
							|  |  |  |       const expectedGrid = [ | 
					
						
							| 
									
										
										
										
											2017-12-19 16:06:54 +01:00
										 |  |  |         { x: 0, y: 0, w: 12, h: 6 }, | 
					
						
							|  |  |  |         { x: 12, y: 0, w: 12, h: 6 }, | 
					
						
							|  |  |  |         { x: 0, y: 6, w: 24, h: 6 }, | 
					
						
							|  |  |  |         { x: 0, y: 12, w: 12, h: 6 }, | 
					
						
							|  |  |  |         { x: 12, y: 12, w: 6, h: 6 }, | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |         { x: 18, y: 12, w: 6, h: 6 }, | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |       ]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       expect(panelGridPos).toEqual(expectedGrid); | 
					
						
							|  |  |  |     }); | 
					
						
							| 
									
										
										
										
											2017-12-05 13:46:58 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-04 15:55:41 +02:00
										 |  |  |     it('should add repeated row if repeat set', () => { | 
					
						
							| 
									
										
										
										
											2017-12-05 13:46:58 +03:00
										 |  |  |       model.rows = [ | 
					
						
							| 
									
										
										
										
											2017-12-21 08:39:31 +01:00
										 |  |  |         createRow({ showTitle: true, title: 'Row', height: 8, repeat: 'server' }, [[6]]), | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |         createRow({ height: 8 }, [[12]]), | 
					
						
							| 
									
										
										
										
											2017-12-05 13:46:58 +03:00
										 |  |  |       ]; | 
					
						
							| 
									
										
										
										
											2018-08-26 17:14:40 +02:00
										 |  |  |       const dashboard = new DashboardModel(model); | 
					
						
							|  |  |  |       const panelGridPos = getGridPositions(dashboard); | 
					
						
							|  |  |  |       const expectedGrid = [ | 
					
						
							| 
									
										
										
										
											2017-12-19 16:06:54 +01:00
										 |  |  |         { x: 0, y: 0, w: 24, h: 8 }, | 
					
						
							|  |  |  |         { x: 0, y: 1, w: 12, h: 8 }, | 
					
						
							|  |  |  |         { x: 0, y: 9, w: 24, h: 8 }, | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |         { x: 0, y: 10, w: 24, h: 8 }, | 
					
						
							| 
									
										
										
										
											2017-12-05 13:46:58 +03:00
										 |  |  |       ]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       expect(panelGridPos).toEqual(expectedGrid); | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |       expect(dashboard.panels[0].repeat).toBe('server'); | 
					
						
							| 
									
										
										
										
											2017-12-05 13:46:58 +03:00
										 |  |  |       expect(dashboard.panels[1].repeat).toBeUndefined(); | 
					
						
							|  |  |  |       expect(dashboard.panels[2].repeat).toBeUndefined(); | 
					
						
							|  |  |  |       expect(dashboard.panels[3].repeat).toBeUndefined(); | 
					
						
							|  |  |  |     }); | 
					
						
							| 
									
										
										
										
											2017-12-14 12:10:32 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-04 15:55:41 +02:00
										 |  |  |     it('should ignore repeated row', () => { | 
					
						
							| 
									
										
										
										
											2017-12-14 12:10:32 +01:00
										 |  |  |       model.rows = [ | 
					
						
							| 
									
										
										
										
											2017-12-21 08:39:31 +01:00
										 |  |  |         createRow({ showTitle: true, title: 'Row1', height: 8, repeat: 'server' }, [[6]]), | 
					
						
							| 
									
										
										
										
											2017-12-19 16:06:54 +01:00
										 |  |  |         createRow( | 
					
						
							|  |  |  |           { | 
					
						
							|  |  |  |             showTitle: true, | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |             title: 'Row2', | 
					
						
							| 
									
										
										
										
											2017-12-19 16:06:54 +01:00
										 |  |  |             height: 8, | 
					
						
							|  |  |  |             repeatIteration: 12313, | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |             repeatRowId: 1, | 
					
						
							| 
									
										
										
										
											2017-12-19 16:06:54 +01:00
										 |  |  |           }, | 
					
						
							|  |  |  |           [[6]] | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |         ), | 
					
						
							| 
									
										
										
										
											2017-12-14 12:10:32 +01:00
										 |  |  |       ]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-26 17:14:40 +02:00
										 |  |  |       const dashboard = new DashboardModel(model); | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |       expect(dashboard.panels[0].repeat).toBe('server'); | 
					
						
							| 
									
										
										
										
											2017-12-14 12:10:32 +01:00
										 |  |  |       expect(dashboard.panels.length).toBe(2); | 
					
						
							|  |  |  |     }); | 
					
						
							| 
									
										
										
										
											2018-02-16 17:29:10 +09:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-04 15:55:41 +02:00
										 |  |  |     it('should assign id', () => { | 
					
						
							| 
									
										
										
										
											2018-02-19 17:07:29 +09:00
										 |  |  |       model.rows = [createRow({ collapse: true, height: 8 }, [[6], [6]])]; | 
					
						
							| 
									
										
										
										
											2018-02-19 13:32:45 +01:00
										 |  |  |       model.rows[0].panels[0] = {}; | 
					
						
							| 
									
										
										
										
											2018-02-19 17:07:29 +09:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-26 17:14:40 +02:00
										 |  |  |       const dashboard = new DashboardModel(model); | 
					
						
							| 
									
										
										
										
											2018-02-19 17:07:29 +09:00
										 |  |  |       expect(dashboard.panels[0].id).toBe(1); | 
					
						
							|  |  |  |     }); | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |   }); | 
					
						
							| 
									
										
										
										
											2018-08-20 15:33:49 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |   describe('when migrating from minSpan to maxPerRow', () => { | 
					
						
							|  |  |  |     it('maxPerRow should be correct', () => { | 
					
						
							|  |  |  |       const model = { | 
					
						
							|  |  |  |         panels: [{ minSpan: 8 }], | 
					
						
							|  |  |  |       }; | 
					
						
							|  |  |  |       const dashboard = new DashboardModel(model); | 
					
						
							|  |  |  |       expect(dashboard.panels[0].maxPerRow).toBe(3); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  |   }); | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | function createRow(options, panelDescriptions: any[]) { | 
					
						
							|  |  |  |   const PANEL_HEIGHT_STEP = GRID_CELL_HEIGHT + GRID_CELL_VMARGIN; | 
					
						
							| 
									
										
										
										
											2018-08-26 20:19:23 +02:00
										 |  |  |   const { collapse, showTitle, title, repeat, repeatIteration } = options; | 
					
						
							|  |  |  |   let { height } = options; | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |   height = height * PANEL_HEIGHT_STEP; | 
					
						
							| 
									
										
										
										
											2018-08-26 17:14:40 +02:00
										 |  |  |   const panels = []; | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |   _.each(panelDescriptions, panelDesc => { | 
					
						
							| 
									
										
										
										
											2018-08-26 17:14:40 +02:00
										 |  |  |     const panel = { span: panelDesc[0] }; | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |     if (panelDesc.length > 1) { | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |       panel['height'] = panelDesc[1] * PANEL_HEIGHT_STEP; | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |     } | 
					
						
							|  |  |  |     panels.push(panel); | 
					
						
							|  |  |  |   }); | 
					
						
							| 
									
										
										
										
											2018-08-26 17:14:40 +02:00
										 |  |  |   const row = { | 
					
						
							| 
									
										
										
										
											2017-12-19 16:06:54 +01:00
										 |  |  |     collapse, | 
					
						
							|  |  |  |     height, | 
					
						
							|  |  |  |     showTitle, | 
					
						
							|  |  |  |     title, | 
					
						
							|  |  |  |     panels, | 
					
						
							|  |  |  |     repeat, | 
					
						
							| 
									
										
										
										
											2017-12-20 12:33:33 +01:00
										 |  |  |     repeatIteration, | 
					
						
							| 
									
										
										
										
											2017-12-19 16:06:54 +01:00
										 |  |  |   }; | 
					
						
							| 
									
										
										
										
											2017-11-27 14:22:52 +03:00
										 |  |  |   return row; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | function getGridPositions(dashboard: DashboardModel) { | 
					
						
							|  |  |  |   return _.map(dashboard.panels, (panel: PanelModel) => { | 
					
						
							|  |  |  |     return panel.gridPos; | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | } |