| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366 |
- import { SingleStatCtrl, ShowData } from '../module';
- import { dateTime, ReducerID } from '@grafana/data';
- import { LinkSrv } from 'app/features/panel/panellinks/link_srv';
- import { LegacyResponseData } from '@grafana/ui';
- interface TestContext {
- ctrl: SingleStatCtrl;
- input: LegacyResponseData[];
- data: Partial<ShowData>;
- setup: (setupFunc: any) => void;
- }
- describe('SingleStatCtrl', () => {
- const ctx: TestContext = {} as TestContext;
- const epoch = 1505826363746;
- Date.now = () => epoch;
- const $scope = {
- $on: () => {},
- };
- const $injector = {
- get: () => {},
- };
- const $sanitize = {};
- SingleStatCtrl.prototype.panel = {
- events: {
- on: () => {},
- emit: () => {},
- },
- };
- SingleStatCtrl.prototype.dashboard = {
- isTimezoneUtc: jest.fn(() => true),
- };
- SingleStatCtrl.prototype.events = {
- on: () => {},
- };
- function singleStatScenario(desc: string, func: any) {
- describe(desc, () => {
- ctx.setup = (setupFunc: any) => {
- beforeEach(() => {
- // @ts-ignore
- ctx.ctrl = new SingleStatCtrl($scope, $injector, {} as LinkSrv, $sanitize);
- setupFunc();
- ctx.ctrl.onDataReceived(ctx.input);
- ctx.data = ctx.ctrl.data;
- });
- };
- func(ctx);
- });
- }
- singleStatScenario('with defaults', (ctx: TestContext) => {
- ctx.setup(() => {
- ctx.input = [{ target: 'test.cpu1', datapoints: [[10, 1], [20, 2]] }];
- });
- it('Should use series avg as default main value', () => {
- expect(ctx.data.value).toBe(15);
- });
- it('should set formatted falue', () => {
- expect(ctx.data.display.text).toBe('15');
- });
- });
- singleStatScenario('showing serie name instead of value', (ctx: TestContext) => {
- ctx.setup(() => {
- ctx.input = [{ target: 'test.cpu1', datapoints: [[10, 1], [20, 2]] }];
- ctx.ctrl.panel.valueName = 'name';
- });
- it('Should use series avg as default main value', () => {
- expect(ctx.data.value).toBe('test.cpu1');
- });
- it('should set formatted value', () => {
- expect(ctx.data.display.text).toBe('test.cpu1');
- });
- });
- singleStatScenario('showing last iso time instead of value', (ctx: TestContext) => {
- ctx.setup(() => {
- ctx.input = [{ target: 'test.cpu1', datapoints: [[10, 12], [20, 1505634997920]] }];
- ctx.ctrl.panel.valueName = 'last_time';
- ctx.ctrl.panel.format = 'dateTimeAsIso';
- ctx.ctrl.dashboard.isTimezoneUtc = () => false;
- });
- it('Should use time instead of value', () => {
- expect(ctx.data.value).toBe(1505634997920);
- });
- it('should set formatted value', () => {
- expect(dateTime(ctx.data.display.text).valueOf()).toBe(1505634997000);
- });
- });
- singleStatScenario('showing last iso time instead of value (in UTC)', (ctx: TestContext) => {
- ctx.setup(() => {
- ctx.input = [{ target: 'test.cpu1', datapoints: [[10, 12], [20, 5000]] }];
- ctx.ctrl.panel.valueName = 'last_time';
- ctx.ctrl.panel.format = 'dateTimeAsIso';
- ctx.ctrl.dashboard.isTimezoneUtc = () => true;
- });
- it('should set value', () => {
- expect(ctx.data.display.text).toBe('1970-01-01 00:00:05');
- });
- });
- singleStatScenario('showing last us time instead of value', (ctx: TestContext) => {
- ctx.setup(() => {
- ctx.input = [{ target: 'test.cpu1', datapoints: [[10, 12], [20, 1505634997920]] }];
- ctx.ctrl.panel.valueName = 'last_time';
- ctx.ctrl.panel.format = 'dateTimeAsUS';
- ctx.ctrl.dashboard.isTimezoneUtc = () => false;
- });
- it('Should use time instead of value', () => {
- expect(ctx.data.value).toBe(1505634997920);
- });
- it('should set formatted value', () => {
- expect(ctx.data.display.text).toBe(dateTime(1505634997920).format('MM/DD/YYYY h:mm:ss a'));
- });
- });
- singleStatScenario('showing last us time instead of value (in UTC)', (ctx: TestContext) => {
- ctx.setup(() => {
- ctx.input = [{ target: 'test.cpu1', datapoints: [[10, 12], [20, 5000]] }];
- ctx.ctrl.panel.valueName = 'last_time';
- ctx.ctrl.panel.format = 'dateTimeAsUS';
- ctx.ctrl.dashboard.isTimezoneUtc = () => true;
- });
- it('should set formatted value', () => {
- expect(ctx.data.display.text).toBe('01/01/1970 12:00:05 am');
- });
- });
- singleStatScenario('showing last time from now instead of value', (ctx: TestContext) => {
- ctx.setup(() => {
- ctx.input = [{ target: 'test.cpu1', datapoints: [[10, 12], [20, 1505634997920]] }];
- ctx.ctrl.panel.valueName = 'last_time';
- ctx.ctrl.panel.format = 'dateTimeFromNow';
- });
- it('Should use time instead of value', () => {
- expect(ctx.data.value).toBe(1505634997920);
- });
- it('should set formatted value', () => {
- expect(ctx.data.display.text).toBe('2 days ago');
- });
- });
- singleStatScenario('showing last time from now instead of value (in UTC)', (ctx: TestContext) => {
- ctx.setup(() => {
- ctx.input = [{ target: 'test.cpu1', datapoints: [[10, 12], [20, 1505634997920]] }];
- ctx.ctrl.panel.valueName = 'last_time';
- ctx.ctrl.panel.format = 'dateTimeFromNow';
- });
- it('should set formatted value', () => {
- expect(ctx.data.display.text).toBe('2 days ago');
- });
- });
- singleStatScenario(
- 'MainValue should use same number for decimals as displayed when checking thresholds',
- (ctx: TestContext) => {
- ctx.setup(() => {
- ctx.input = [{ target: 'test.cpu1', datapoints: [[99.999, 1], [99.99999, 2]] }];
- ctx.ctrl.panel.valueName = 'avg';
- ctx.ctrl.panel.format = 'none';
- });
- it('Should be rounded', () => {
- expect(ctx.data.value).toBe(99.999495);
- });
- it('should set formatted value', () => {
- expect(ctx.data.display.text).toBe('100');
- });
- }
- );
- singleStatScenario('When value to text mapping is specified', (ctx: TestContext) => {
- ctx.setup(() => {
- ctx.input = [{ target: 'test.cpu1', datapoints: [[9.9, 1]] }];
- ctx.ctrl.panel.valueMaps = [{ value: '10', text: 'OK' }];
- });
- it('value should remain', () => {
- expect(ctx.data.value).toBe(9.9);
- });
- it('Should replace value with text', () => {
- expect(ctx.data.display.text).toBe('OK');
- });
- });
- singleStatScenario('When range to text mapping is specified for first range', (ctx: TestContext) => {
- ctx.setup(() => {
- ctx.input = [{ target: 'test.cpu1', datapoints: [[41, 50]] }];
- ctx.ctrl.panel.mappingType = 2;
- ctx.ctrl.panel.rangeMaps = [{ from: '10', to: '50', text: 'OK' }, { from: '51', to: '100', text: 'NOT OK' }];
- });
- it('Should replace value with text OK', () => {
- expect(ctx.data.display.text).toBe('OK');
- });
- });
- singleStatScenario('When range to text mapping is specified for other ranges', (ctx: TestContext) => {
- ctx.setup(() => {
- ctx.input = [{ target: 'test.cpu1', datapoints: [[65, 75]] }];
- ctx.ctrl.panel.mappingType = 2;
- ctx.ctrl.panel.rangeMaps = [{ from: '10', to: '50', text: 'OK' }, { from: '51', to: '100', text: 'NOT OK' }];
- });
- it('Should replace value with text NOT OK', () => {
- expect(ctx.data.display.text).toBe('NOT OK');
- });
- });
- describe('When table data', () => {
- const tableData = [
- {
- columns: [{ text: 'Time', type: 'time' }, { text: 'test1' }, { text: 'mean' }, { text: 'test2' }],
- rows: [[1492759673649, 'ignore1', 15, 'ignore2']],
- type: 'table',
- },
- ];
- singleStatScenario('with default values', (ctx: TestContext) => {
- ctx.setup(() => {
- ctx.input = tableData;
- ctx.ctrl.panel = {
- emit: () => {},
- };
- ctx.ctrl.panel.tableColumn = 'mean';
- ctx.ctrl.panel.format = 'none';
- });
- it('Should use first rows value as default main value', () => {
- expect(ctx.data.value).toBe(15);
- });
- it('should set formatted value', () => {
- expect(ctx.data.display.text).toBe('15');
- });
- });
- singleStatScenario('When table data has multiple columns', (ctx: TestContext) => {
- ctx.setup(() => {
- ctx.input = tableData;
- ctx.ctrl.panel.tableColumn = '';
- });
- it('Should set column to first column that is not time', () => {
- expect(ctx.ctrl.panel.tableColumn).toBe('test1');
- });
- });
- singleStatScenario(
- 'MainValue should use same number for decimals as displayed when checking thresholds',
- (ctx: TestContext) => {
- ctx.setup(() => {
- ctx.input = tableData;
- ctx.input[0].rows[0] = [1492759673649, 'ignore1', 99.99999, 'ignore2'];
- ctx.ctrl.panel.mappingType = 0;
- ctx.ctrl.panel.tableColumn = 'mean';
- });
- it('Should be rounded', () => {
- expect(ctx.data.value).toBe(99.99999);
- });
- it('should set formatted falue', () => {
- expect(ctx.data.display.text).toBe('100');
- });
- }
- );
- singleStatScenario('When value to text mapping is specified', (ctx: TestContext) => {
- ctx.setup(() => {
- ctx.input = tableData;
- ctx.input[0].rows[0] = [1492759673649, 'ignore1', 9.9, 'ignore2'];
- ctx.ctrl.panel.mappingType = 2;
- ctx.ctrl.panel.tableColumn = 'mean';
- ctx.ctrl.panel.valueMaps = [{ value: '10', text: 'OK' }];
- });
- it('value should remain', () => {
- expect(ctx.data.value).toBe(9.9);
- });
- // it('round should be rounded up', () => {
- // expect(ctx.data.valueRounded).toBe(10);
- // });
- it('Should replace value with text', () => {
- expect(ctx.data.display.text).toBe('OK');
- });
- });
- singleStatScenario('When range to text mapping is specified for first range', (ctx: TestContext) => {
- ctx.setup(() => {
- ctx.input = tableData;
- ctx.input[0].rows[0] = [1492759673649, 'ignore1', 41, 'ignore2'];
- ctx.ctrl.panel.tableColumn = 'mean';
- ctx.ctrl.panel.mappingType = 2;
- ctx.ctrl.panel.rangeMaps = [{ from: '10', to: '50', text: 'OK' }, { from: '51', to: '100', text: 'NOT OK' }];
- });
- it('Should replace value with text OK', () => {
- expect(ctx.data.display.text).toBe('OK');
- });
- });
- singleStatScenario('When range to text mapping is specified for other ranges', (ctx: TestContext) => {
- ctx.setup(() => {
- ctx.input = tableData;
- ctx.input[0].rows[0] = [1492759673649, 'ignore1', 65, 'ignore2'];
- ctx.ctrl.panel.tableColumn = 'mean';
- ctx.ctrl.panel.mappingType = 2;
- ctx.ctrl.panel.rangeMaps = [{ from: '10', to: '50', text: 'OK' }, { from: '51', to: '100', text: 'NOT OK' }];
- });
- it('Should replace value with text NOT OK', () => {
- expect(ctx.data.display.text).toBe('NOT OK');
- });
- });
- singleStatScenario('When value is string', (ctx: TestContext) => {
- ctx.setup(() => {
- ctx.input = tableData;
- ctx.input[0].rows[0] = [1492759673649, 'ignore1', 65, 'ignore2'];
- ctx.ctrl.panel.tableColumn = 'test1';
- ctx.ctrl.panel.valueName = ReducerID.first;
- });
- it('Should replace value with text NOT OK', () => {
- expect(ctx.data.display.text).toBe('ignore1');
- });
- });
- singleStatScenario('When value is zero', (ctx: TestContext) => {
- ctx.setup(() => {
- ctx.input = tableData;
- ctx.input[0].rows[0] = [1492759673649, 'ignore1', 0, 'ignore2'];
- ctx.ctrl.panel.tableColumn = 'mean';
- });
- it('Should return zero', () => {
- expect(ctx.data.value).toBe(0);
- });
- });
- });
- });
|