2022-04-22 08:33:13 -05:00
|
|
|
import { advanceTo, clear } from 'jest-date-mock';
|
|
|
|
import { ComponentClass } from 'react';
|
|
|
|
|
2020-03-12 04:22:33 -05:00
|
|
|
import { dateTime, DateTime, PanelProps, TimeRange } from '@grafana/data';
|
2019-11-25 15:26:18 -06:00
|
|
|
import { applyPanelTimeOverrides, calculateInnerPanelHeight } from 'app/features/dashboard/utils/panel';
|
2022-04-22 08:33:13 -05:00
|
|
|
|
2019-11-25 15:26:18 -06:00
|
|
|
import { getPanelPlugin } from '../../plugins/__mocks__/pluginMocks';
|
2022-04-22 08:33:13 -05:00
|
|
|
import { PanelModel } from '../state';
|
2019-01-11 09:19:34 -06:00
|
|
|
|
|
|
|
const dashboardTimeRange: TimeRange = {
|
2019-05-08 06:51:44 -05:00
|
|
|
from: dateTime([2019, 1, 11, 12, 0]),
|
|
|
|
to: dateTime([2019, 1, 11, 18, 0]),
|
2019-01-11 09:19:34 -06:00
|
|
|
raw: {
|
|
|
|
from: 'now-6h',
|
|
|
|
to: 'now',
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
describe('applyPanelTimeOverrides', () => {
|
2019-05-08 06:51:44 -05:00
|
|
|
const fakeCurrentDate = dateTime([2019, 1, 11, 14, 0, 0]).toDate();
|
2019-01-11 09:19:34 -06:00
|
|
|
|
|
|
|
beforeAll(() => {
|
|
|
|
advanceTo(fakeCurrentDate);
|
|
|
|
});
|
|
|
|
|
|
|
|
afterAll(() => {
|
|
|
|
clear();
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should apply relative time override', () => {
|
|
|
|
const panelModel = {
|
|
|
|
timeFrom: '2h',
|
|
|
|
};
|
|
|
|
|
2021-04-01 10:42:57 -05:00
|
|
|
// @ts-ignore: PanelModel type inconsistency
|
2019-01-11 09:19:34 -06:00
|
|
|
const overrides = applyPanelTimeOverrides(panelModel, dashboardTimeRange);
|
|
|
|
|
2019-05-08 06:51:44 -05:00
|
|
|
expect(overrides.timeRange.from.toISOString()).toBe(dateTime([2019, 1, 11, 12]).toISOString());
|
2019-01-11 09:19:34 -06:00
|
|
|
expect(overrides.timeRange.to.toISOString()).toBe(fakeCurrentDate.toISOString());
|
2019-01-11 09:49:29 -06:00
|
|
|
expect(overrides.timeRange.raw.from).toBe('now-2h');
|
|
|
|
expect(overrides.timeRange.raw.to).toBe('now');
|
2019-01-11 09:19:34 -06:00
|
|
|
});
|
|
|
|
|
|
|
|
it('should apply time shift', () => {
|
|
|
|
const panelModel = {
|
2019-02-13 04:14:53 -06:00
|
|
|
timeShift: '2h',
|
2019-01-11 09:19:34 -06:00
|
|
|
};
|
|
|
|
|
2019-05-08 06:51:44 -05:00
|
|
|
const expectedFromDate = dateTime([2019, 1, 11, 10, 0, 0]).toDate();
|
|
|
|
const expectedToDate = dateTime([2019, 1, 11, 16, 0, 0]).toDate();
|
2019-01-11 09:19:34 -06:00
|
|
|
|
2021-04-01 10:42:57 -05:00
|
|
|
// @ts-ignore: PanelModel type inconsistency
|
2019-01-11 09:19:34 -06:00
|
|
|
const overrides = applyPanelTimeOverrides(panelModel, dashboardTimeRange);
|
|
|
|
|
|
|
|
expect(overrides.timeRange.from.toISOString()).toBe(expectedFromDate.toISOString());
|
|
|
|
expect(overrides.timeRange.to.toISOString()).toBe(expectedToDate.toISOString());
|
2019-05-08 06:51:44 -05:00
|
|
|
expect((overrides.timeRange.raw.from as DateTime).toISOString()).toEqual(expectedFromDate.toISOString());
|
|
|
|
expect((overrides.timeRange.raw.to as DateTime).toISOString()).toEqual(expectedToDate.toISOString());
|
2019-01-11 09:19:34 -06:00
|
|
|
});
|
|
|
|
|
|
|
|
it('should apply both relative time and time shift', () => {
|
|
|
|
const panelModel = {
|
|
|
|
timeFrom: '2h',
|
2019-02-13 04:14:53 -06:00
|
|
|
timeShift: '2h',
|
2019-01-11 09:19:34 -06:00
|
|
|
};
|
|
|
|
|
2019-05-08 06:51:44 -05:00
|
|
|
const expectedFromDate = dateTime([2019, 1, 11, 10, 0, 0]).toDate();
|
|
|
|
const expectedToDate = dateTime([2019, 1, 11, 12, 0, 0]).toDate();
|
2019-01-11 09:19:34 -06:00
|
|
|
|
2021-04-01 10:42:57 -05:00
|
|
|
// @ts-ignore: PanelModel type inconsistency
|
2019-01-11 09:19:34 -06:00
|
|
|
const overrides = applyPanelTimeOverrides(panelModel, dashboardTimeRange);
|
|
|
|
|
|
|
|
expect(overrides.timeRange.from.toISOString()).toBe(expectedFromDate.toISOString());
|
|
|
|
expect(overrides.timeRange.to.toISOString()).toBe(expectedToDate.toISOString());
|
2019-05-08 06:51:44 -05:00
|
|
|
expect((overrides.timeRange.raw.from as DateTime).toISOString()).toEqual(expectedFromDate.toISOString());
|
|
|
|
expect((overrides.timeRange.raw.to as DateTime).toISOString()).toEqual(expectedToDate.toISOString());
|
2019-01-11 09:19:34 -06:00
|
|
|
});
|
2019-11-25 15:26:18 -06:00
|
|
|
|
|
|
|
it('Calculate panel height', () => {
|
|
|
|
const panelModel = new PanelModel({});
|
|
|
|
const height = calculateInnerPanelHeight(panelModel, 100);
|
|
|
|
|
|
|
|
expect(height).toBe(82);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('Calculate panel height with panel plugin zeroChromePadding', () => {
|
|
|
|
const panelModel = new PanelModel({});
|
2020-03-12 04:22:33 -05:00
|
|
|
panelModel.pluginLoaded(
|
2022-02-02 06:02:32 -06:00
|
|
|
getPanelPlugin({ id: 'table' }, null as unknown as ComponentClass<PanelProps>, null).setNoPadding()
|
2020-03-12 04:22:33 -05:00
|
|
|
);
|
2019-11-25 15:26:18 -06:00
|
|
|
|
|
|
|
const height = calculateInnerPanelHeight(panelModel, 100);
|
|
|
|
expect(height).toBe(98);
|
|
|
|
});
|
2019-01-11 09:19:34 -06:00
|
|
|
});
|