|
@@ -1,9 +1,17 @@
|
|
|
-import { SingleStatCtrl } from '../module';
|
|
|
|
|
-import { dateTime } from '@grafana/data';
|
|
|
|
|
|
|
+import { SingleStatCtrl, ShowData } from '../module';
|
|
|
|
|
+import { dateTime, ReducerID } from '@grafana/data';
|
|
|
import { LinkSrv } from 'app/features/panel/panellinks/link_srv';
|
|
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', () => {
|
|
describe('SingleStatCtrl', () => {
|
|
|
- const ctx = {} as any;
|
|
|
|
|
|
|
+ const ctx: TestContext = {} as TestContext;
|
|
|
const epoch = 1505826363746;
|
|
const epoch = 1505826363746;
|
|
|
Date.now = () => epoch;
|
|
Date.now = () => epoch;
|
|
|
|
|
|
|
@@ -37,7 +45,7 @@ describe('SingleStatCtrl', () => {
|
|
|
// @ts-ignore
|
|
// @ts-ignore
|
|
|
ctx.ctrl = new SingleStatCtrl($scope, $injector, {} as LinkSrv, $sanitize);
|
|
ctx.ctrl = new SingleStatCtrl($scope, $injector, {} as LinkSrv, $sanitize);
|
|
|
setupFunc();
|
|
setupFunc();
|
|
|
- ctx.ctrl.onDataReceived(ctx.data);
|
|
|
|
|
|
|
+ ctx.ctrl.onDataReceived(ctx.input);
|
|
|
ctx.data = ctx.ctrl.data;
|
|
ctx.data = ctx.ctrl.data;
|
|
|
});
|
|
});
|
|
|
};
|
|
};
|
|
@@ -46,40 +54,38 @@ describe('SingleStatCtrl', () => {
|
|
|
});
|
|
});
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
- singleStatScenario('with defaults', (ctx: any) => {
|
|
|
|
|
|
|
+ singleStatScenario('with defaults', (ctx: TestContext) => {
|
|
|
ctx.setup(() => {
|
|
ctx.setup(() => {
|
|
|
- ctx.data = [{ target: 'test.cpu1', datapoints: [[10, 1], [20, 2]] }];
|
|
|
|
|
|
|
+ ctx.input = [{ target: 'test.cpu1', datapoints: [[10, 1], [20, 2]] }];
|
|
|
});
|
|
});
|
|
|
|
|
|
|
|
it('Should use series avg as default main value', () => {
|
|
it('Should use series avg as default main value', () => {
|
|
|
expect(ctx.data.value).toBe(15);
|
|
expect(ctx.data.value).toBe(15);
|
|
|
- expect(ctx.data.valueRounded).toBe(15);
|
|
|
|
|
});
|
|
});
|
|
|
|
|
|
|
|
it('should set formatted falue', () => {
|
|
it('should set formatted falue', () => {
|
|
|
- expect(ctx.data.valueFormatted).toBe('15');
|
|
|
|
|
|
|
+ expect(ctx.data.display.text).toBe('15');
|
|
|
});
|
|
});
|
|
|
});
|
|
});
|
|
|
|
|
|
|
|
- singleStatScenario('showing serie name instead of value', (ctx: any) => {
|
|
|
|
|
|
|
+ singleStatScenario('showing serie name instead of value', (ctx: TestContext) => {
|
|
|
ctx.setup(() => {
|
|
ctx.setup(() => {
|
|
|
- ctx.data = [{ target: 'test.cpu1', datapoints: [[10, 1], [20, 2]] }];
|
|
|
|
|
|
|
+ ctx.input = [{ target: 'test.cpu1', datapoints: [[10, 1], [20, 2]] }];
|
|
|
ctx.ctrl.panel.valueName = 'name';
|
|
ctx.ctrl.panel.valueName = 'name';
|
|
|
});
|
|
});
|
|
|
|
|
|
|
|
it('Should use series avg as default main value', () => {
|
|
it('Should use series avg as default main value', () => {
|
|
|
- expect(ctx.data.value).toBe(0);
|
|
|
|
|
- expect(ctx.data.valueRounded).toBe(0);
|
|
|
|
|
|
|
+ expect(ctx.data.value).toBe('test.cpu1');
|
|
|
});
|
|
});
|
|
|
|
|
|
|
|
it('should set formatted value', () => {
|
|
it('should set formatted value', () => {
|
|
|
- expect(ctx.data.valueFormatted).toBe('test.cpu1');
|
|
|
|
|
|
|
+ expect(ctx.data.display.text).toBe('test.cpu1');
|
|
|
});
|
|
});
|
|
|
});
|
|
});
|
|
|
|
|
|
|
|
- singleStatScenario('showing last iso time instead of value', (ctx: any) => {
|
|
|
|
|
|
|
+ singleStatScenario('showing last iso time instead of value', (ctx: TestContext) => {
|
|
|
ctx.setup(() => {
|
|
ctx.setup(() => {
|
|
|
- ctx.data = [{ target: 'test.cpu1', datapoints: [[10, 12], [20, 1505634997920]] }];
|
|
|
|
|
|
|
+ ctx.input = [{ target: 'test.cpu1', datapoints: [[10, 12], [20, 1505634997920]] }];
|
|
|
ctx.ctrl.panel.valueName = 'last_time';
|
|
ctx.ctrl.panel.valueName = 'last_time';
|
|
|
ctx.ctrl.panel.format = 'dateTimeAsIso';
|
|
ctx.ctrl.panel.format = 'dateTimeAsIso';
|
|
|
ctx.ctrl.dashboard.isTimezoneUtc = () => false;
|
|
ctx.ctrl.dashboard.isTimezoneUtc = () => false;
|
|
@@ -87,30 +93,29 @@ describe('SingleStatCtrl', () => {
|
|
|
|
|
|
|
|
it('Should use time instead of value', () => {
|
|
it('Should use time instead of value', () => {
|
|
|
expect(ctx.data.value).toBe(1505634997920);
|
|
expect(ctx.data.value).toBe(1505634997920);
|
|
|
- expect(ctx.data.valueRounded).toBe(1505634997920);
|
|
|
|
|
});
|
|
});
|
|
|
|
|
|
|
|
it('should set formatted value', () => {
|
|
it('should set formatted value', () => {
|
|
|
- expect(dateTime(ctx.data.valueFormatted).valueOf()).toBe(1505634997000);
|
|
|
|
|
|
|
+ expect(dateTime(ctx.data.display.text).valueOf()).toBe(1505634997000);
|
|
|
});
|
|
});
|
|
|
});
|
|
});
|
|
|
|
|
|
|
|
- singleStatScenario('showing last iso time instead of value (in UTC)', (ctx: any) => {
|
|
|
|
|
|
|
+ singleStatScenario('showing last iso time instead of value (in UTC)', (ctx: TestContext) => {
|
|
|
ctx.setup(() => {
|
|
ctx.setup(() => {
|
|
|
- ctx.data = [{ target: 'test.cpu1', datapoints: [[10, 12], [20, 5000]] }];
|
|
|
|
|
|
|
+ ctx.input = [{ target: 'test.cpu1', datapoints: [[10, 12], [20, 5000]] }];
|
|
|
ctx.ctrl.panel.valueName = 'last_time';
|
|
ctx.ctrl.panel.valueName = 'last_time';
|
|
|
ctx.ctrl.panel.format = 'dateTimeAsIso';
|
|
ctx.ctrl.panel.format = 'dateTimeAsIso';
|
|
|
ctx.ctrl.dashboard.isTimezoneUtc = () => true;
|
|
ctx.ctrl.dashboard.isTimezoneUtc = () => true;
|
|
|
});
|
|
});
|
|
|
|
|
|
|
|
it('should set value', () => {
|
|
it('should set value', () => {
|
|
|
- expect(ctx.data.valueFormatted).toBe('1970-01-01 00:00:05');
|
|
|
|
|
|
|
+ expect(ctx.data.display.text).toBe('1970-01-01 00:00:05');
|
|
|
});
|
|
});
|
|
|
});
|
|
});
|
|
|
|
|
|
|
|
- singleStatScenario('showing last us time instead of value', (ctx: any) => {
|
|
|
|
|
|
|
+ singleStatScenario('showing last us time instead of value', (ctx: TestContext) => {
|
|
|
ctx.setup(() => {
|
|
ctx.setup(() => {
|
|
|
- ctx.data = [{ target: 'test.cpu1', datapoints: [[10, 12], [20, 1505634997920]] }];
|
|
|
|
|
|
|
+ ctx.input = [{ target: 'test.cpu1', datapoints: [[10, 12], [20, 1505634997920]] }];
|
|
|
ctx.ctrl.panel.valueName = 'last_time';
|
|
ctx.ctrl.panel.valueName = 'last_time';
|
|
|
ctx.ctrl.panel.format = 'dateTimeAsUS';
|
|
ctx.ctrl.panel.format = 'dateTimeAsUS';
|
|
|
ctx.ctrl.dashboard.isTimezoneUtc = () => false;
|
|
ctx.ctrl.dashboard.isTimezoneUtc = () => false;
|
|
@@ -118,79 +123,76 @@ describe('SingleStatCtrl', () => {
|
|
|
|
|
|
|
|
it('Should use time instead of value', () => {
|
|
it('Should use time instead of value', () => {
|
|
|
expect(ctx.data.value).toBe(1505634997920);
|
|
expect(ctx.data.value).toBe(1505634997920);
|
|
|
- expect(ctx.data.valueRounded).toBe(1505634997920);
|
|
|
|
|
});
|
|
});
|
|
|
|
|
|
|
|
it('should set formatted value', () => {
|
|
it('should set formatted value', () => {
|
|
|
- expect(ctx.data.valueFormatted).toBe(dateTime(1505634997920).format('MM/DD/YYYY h:mm:ss a'));
|
|
|
|
|
|
|
+ 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: any) => {
|
|
|
|
|
|
|
+ singleStatScenario('showing last us time instead of value (in UTC)', (ctx: TestContext) => {
|
|
|
ctx.setup(() => {
|
|
ctx.setup(() => {
|
|
|
- ctx.data = [{ target: 'test.cpu1', datapoints: [[10, 12], [20, 5000]] }];
|
|
|
|
|
|
|
+ ctx.input = [{ target: 'test.cpu1', datapoints: [[10, 12], [20, 5000]] }];
|
|
|
ctx.ctrl.panel.valueName = 'last_time';
|
|
ctx.ctrl.panel.valueName = 'last_time';
|
|
|
ctx.ctrl.panel.format = 'dateTimeAsUS';
|
|
ctx.ctrl.panel.format = 'dateTimeAsUS';
|
|
|
ctx.ctrl.dashboard.isTimezoneUtc = () => true;
|
|
ctx.ctrl.dashboard.isTimezoneUtc = () => true;
|
|
|
});
|
|
});
|
|
|
|
|
|
|
|
it('should set formatted value', () => {
|
|
it('should set formatted value', () => {
|
|
|
- expect(ctx.data.valueFormatted).toBe('01/01/1970 12:00:05 am');
|
|
|
|
|
|
|
+ expect(ctx.data.display.text).toBe('01/01/1970 12:00:05 am');
|
|
|
});
|
|
});
|
|
|
});
|
|
});
|
|
|
|
|
|
|
|
- singleStatScenario('showing last time from now instead of value', (ctx: any) => {
|
|
|
|
|
|
|
+ singleStatScenario('showing last time from now instead of value', (ctx: TestContext) => {
|
|
|
ctx.setup(() => {
|
|
ctx.setup(() => {
|
|
|
- ctx.data = [{ target: 'test.cpu1', datapoints: [[10, 12], [20, 1505634997920]] }];
|
|
|
|
|
|
|
+ ctx.input = [{ target: 'test.cpu1', datapoints: [[10, 12], [20, 1505634997920]] }];
|
|
|
ctx.ctrl.panel.valueName = 'last_time';
|
|
ctx.ctrl.panel.valueName = 'last_time';
|
|
|
ctx.ctrl.panel.format = 'dateTimeFromNow';
|
|
ctx.ctrl.panel.format = 'dateTimeFromNow';
|
|
|
});
|
|
});
|
|
|
|
|
|
|
|
it('Should use time instead of value', () => {
|
|
it('Should use time instead of value', () => {
|
|
|
expect(ctx.data.value).toBe(1505634997920);
|
|
expect(ctx.data.value).toBe(1505634997920);
|
|
|
- expect(ctx.data.valueRounded).toBe(1505634997920);
|
|
|
|
|
});
|
|
});
|
|
|
|
|
|
|
|
it('should set formatted value', () => {
|
|
it('should set formatted value', () => {
|
|
|
- expect(ctx.data.valueFormatted).toBe('2 days ago');
|
|
|
|
|
|
|
+ expect(ctx.data.display.text).toBe('2 days ago');
|
|
|
});
|
|
});
|
|
|
});
|
|
});
|
|
|
|
|
|
|
|
- singleStatScenario('showing last time from now instead of value (in UTC)', (ctx: any) => {
|
|
|
|
|
|
|
+ singleStatScenario('showing last time from now instead of value (in UTC)', (ctx: TestContext) => {
|
|
|
ctx.setup(() => {
|
|
ctx.setup(() => {
|
|
|
- ctx.data = [{ target: 'test.cpu1', datapoints: [[10, 12], [20, 1505634997920]] }];
|
|
|
|
|
|
|
+ ctx.input = [{ target: 'test.cpu1', datapoints: [[10, 12], [20, 1505634997920]] }];
|
|
|
ctx.ctrl.panel.valueName = 'last_time';
|
|
ctx.ctrl.panel.valueName = 'last_time';
|
|
|
ctx.ctrl.panel.format = 'dateTimeFromNow';
|
|
ctx.ctrl.panel.format = 'dateTimeFromNow';
|
|
|
});
|
|
});
|
|
|
|
|
|
|
|
it('should set formatted value', () => {
|
|
it('should set formatted value', () => {
|
|
|
- expect(ctx.data.valueFormatted).toBe('2 days ago');
|
|
|
|
|
|
|
+ expect(ctx.data.display.text).toBe('2 days ago');
|
|
|
});
|
|
});
|
|
|
});
|
|
});
|
|
|
|
|
|
|
|
singleStatScenario(
|
|
singleStatScenario(
|
|
|
'MainValue should use same number for decimals as displayed when checking thresholds',
|
|
'MainValue should use same number for decimals as displayed when checking thresholds',
|
|
|
- (ctx: any) => {
|
|
|
|
|
|
|
+ (ctx: TestContext) => {
|
|
|
ctx.setup(() => {
|
|
ctx.setup(() => {
|
|
|
- ctx.data = [{ target: 'test.cpu1', datapoints: [[99.999, 1], [99.99999, 2]] }];
|
|
|
|
|
|
|
+ ctx.input = [{ target: 'test.cpu1', datapoints: [[99.999, 1], [99.99999, 2]] }];
|
|
|
ctx.ctrl.panel.valueName = 'avg';
|
|
ctx.ctrl.panel.valueName = 'avg';
|
|
|
ctx.ctrl.panel.format = 'none';
|
|
ctx.ctrl.panel.format = 'none';
|
|
|
});
|
|
});
|
|
|
|
|
|
|
|
it('Should be rounded', () => {
|
|
it('Should be rounded', () => {
|
|
|
expect(ctx.data.value).toBe(99.999495);
|
|
expect(ctx.data.value).toBe(99.999495);
|
|
|
- expect(ctx.data.valueRounded).toBe(100);
|
|
|
|
|
});
|
|
});
|
|
|
|
|
|
|
|
it('should set formatted value', () => {
|
|
it('should set formatted value', () => {
|
|
|
- expect(ctx.data.valueFormatted).toBe('100');
|
|
|
|
|
|
|
+ expect(ctx.data.display.text).toBe('100');
|
|
|
});
|
|
});
|
|
|
}
|
|
}
|
|
|
);
|
|
);
|
|
|
|
|
|
|
|
- singleStatScenario('When value to text mapping is specified', (ctx: any) => {
|
|
|
|
|
|
|
+ singleStatScenario('When value to text mapping is specified', (ctx: TestContext) => {
|
|
|
ctx.setup(() => {
|
|
ctx.setup(() => {
|
|
|
- ctx.data = [{ target: 'test.cpu1', datapoints: [[9.9, 1]] }];
|
|
|
|
|
|
|
+ ctx.input = [{ target: 'test.cpu1', datapoints: [[9.9, 1]] }];
|
|
|
ctx.ctrl.panel.valueMaps = [{ value: '10', text: 'OK' }];
|
|
ctx.ctrl.panel.valueMaps = [{ value: '10', text: 'OK' }];
|
|
|
});
|
|
});
|
|
|
|
|
|
|
@@ -198,36 +200,32 @@ describe('SingleStatCtrl', () => {
|
|
|
expect(ctx.data.value).toBe(9.9);
|
|
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', () => {
|
|
it('Should replace value with text', () => {
|
|
|
- expect(ctx.data.valueFormatted).toBe('OK');
|
|
|
|
|
|
|
+ expect(ctx.data.display.text).toBe('OK');
|
|
|
});
|
|
});
|
|
|
});
|
|
});
|
|
|
|
|
|
|
|
- singleStatScenario('When range to text mapping is specified for first range', (ctx: any) => {
|
|
|
|
|
|
|
+ singleStatScenario('When range to text mapping is specified for first range', (ctx: TestContext) => {
|
|
|
ctx.setup(() => {
|
|
ctx.setup(() => {
|
|
|
- ctx.data = [{ target: 'test.cpu1', datapoints: [[41, 50]] }];
|
|
|
|
|
|
|
+ ctx.input = [{ target: 'test.cpu1', datapoints: [[41, 50]] }];
|
|
|
ctx.ctrl.panel.mappingType = 2;
|
|
ctx.ctrl.panel.mappingType = 2;
|
|
|
ctx.ctrl.panel.rangeMaps = [{ from: '10', to: '50', text: 'OK' }, { from: '51', to: '100', text: 'NOT OK' }];
|
|
ctx.ctrl.panel.rangeMaps = [{ from: '10', to: '50', text: 'OK' }, { from: '51', to: '100', text: 'NOT OK' }];
|
|
|
});
|
|
});
|
|
|
|
|
|
|
|
it('Should replace value with text OK', () => {
|
|
it('Should replace value with text OK', () => {
|
|
|
- expect(ctx.data.valueFormatted).toBe('OK');
|
|
|
|
|
|
|
+ expect(ctx.data.display.text).toBe('OK');
|
|
|
});
|
|
});
|
|
|
});
|
|
});
|
|
|
|
|
|
|
|
- singleStatScenario('When range to text mapping is specified for other ranges', (ctx: any) => {
|
|
|
|
|
|
|
+ singleStatScenario('When range to text mapping is specified for other ranges', (ctx: TestContext) => {
|
|
|
ctx.setup(() => {
|
|
ctx.setup(() => {
|
|
|
- ctx.data = [{ target: 'test.cpu1', datapoints: [[65, 75]] }];
|
|
|
|
|
|
|
+ ctx.input = [{ target: 'test.cpu1', datapoints: [[65, 75]] }];
|
|
|
ctx.ctrl.panel.mappingType = 2;
|
|
ctx.ctrl.panel.mappingType = 2;
|
|
|
ctx.ctrl.panel.rangeMaps = [{ from: '10', to: '50', text: 'OK' }, { from: '51', to: '100', text: 'NOT OK' }];
|
|
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', () => {
|
|
it('Should replace value with text NOT OK', () => {
|
|
|
- expect(ctx.data.valueFormatted).toBe('NOT OK');
|
|
|
|
|
|
|
+ expect(ctx.data.display.text).toBe('NOT OK');
|
|
|
});
|
|
});
|
|
|
});
|
|
});
|
|
|
|
|
|
|
@@ -240,9 +238,9 @@ describe('SingleStatCtrl', () => {
|
|
|
},
|
|
},
|
|
|
];
|
|
];
|
|
|
|
|
|
|
|
- singleStatScenario('with default values', (ctx: any) => {
|
|
|
|
|
|
|
+ singleStatScenario('with default values', (ctx: TestContext) => {
|
|
|
ctx.setup(() => {
|
|
ctx.setup(() => {
|
|
|
- ctx.data = tableData;
|
|
|
|
|
|
|
+ ctx.input = tableData;
|
|
|
ctx.ctrl.panel = {
|
|
ctx.ctrl.panel = {
|
|
|
emit: () => {},
|
|
emit: () => {},
|
|
|
};
|
|
};
|
|
@@ -252,17 +250,16 @@ describe('SingleStatCtrl', () => {
|
|
|
|
|
|
|
|
it('Should use first rows value as default main value', () => {
|
|
it('Should use first rows value as default main value', () => {
|
|
|
expect(ctx.data.value).toBe(15);
|
|
expect(ctx.data.value).toBe(15);
|
|
|
- expect(ctx.data.valueRounded).toBe(15);
|
|
|
|
|
});
|
|
});
|
|
|
|
|
|
|
|
it('should set formatted value', () => {
|
|
it('should set formatted value', () => {
|
|
|
- expect(ctx.data.valueFormatted).toBe('15');
|
|
|
|
|
|
|
+ expect(ctx.data.display.text).toBe('15');
|
|
|
});
|
|
});
|
|
|
});
|
|
});
|
|
|
|
|
|
|
|
- singleStatScenario('When table data has multiple columns', (ctx: any) => {
|
|
|
|
|
|
|
+ singleStatScenario('When table data has multiple columns', (ctx: TestContext) => {
|
|
|
ctx.setup(() => {
|
|
ctx.setup(() => {
|
|
|
- ctx.data = tableData;
|
|
|
|
|
|
|
+ ctx.input = tableData;
|
|
|
ctx.ctrl.panel.tableColumn = '';
|
|
ctx.ctrl.panel.tableColumn = '';
|
|
|
});
|
|
});
|
|
|
|
|
|
|
@@ -273,29 +270,28 @@ describe('SingleStatCtrl', () => {
|
|
|
|
|
|
|
|
singleStatScenario(
|
|
singleStatScenario(
|
|
|
'MainValue should use same number for decimals as displayed when checking thresholds',
|
|
'MainValue should use same number for decimals as displayed when checking thresholds',
|
|
|
- (ctx: any) => {
|
|
|
|
|
|
|
+ (ctx: TestContext) => {
|
|
|
ctx.setup(() => {
|
|
ctx.setup(() => {
|
|
|
- ctx.data = tableData;
|
|
|
|
|
- ctx.data[0].rows[0] = [1492759673649, 'ignore1', 99.99999, 'ignore2'];
|
|
|
|
|
|
|
+ ctx.input = tableData;
|
|
|
|
|
+ ctx.input[0].rows[0] = [1492759673649, 'ignore1', 99.99999, 'ignore2'];
|
|
|
ctx.ctrl.panel.mappingType = 0;
|
|
ctx.ctrl.panel.mappingType = 0;
|
|
|
ctx.ctrl.panel.tableColumn = 'mean';
|
|
ctx.ctrl.panel.tableColumn = 'mean';
|
|
|
});
|
|
});
|
|
|
|
|
|
|
|
it('Should be rounded', () => {
|
|
it('Should be rounded', () => {
|
|
|
expect(ctx.data.value).toBe(99.99999);
|
|
expect(ctx.data.value).toBe(99.99999);
|
|
|
- expect(ctx.data.valueRounded).toBe(100);
|
|
|
|
|
});
|
|
});
|
|
|
|
|
|
|
|
it('should set formatted falue', () => {
|
|
it('should set formatted falue', () => {
|
|
|
- expect(ctx.data.valueFormatted).toBe('100');
|
|
|
|
|
|
|
+ expect(ctx.data.display.text).toBe('100');
|
|
|
});
|
|
});
|
|
|
}
|
|
}
|
|
|
);
|
|
);
|
|
|
|
|
|
|
|
- singleStatScenario('When value to text mapping is specified', (ctx: any) => {
|
|
|
|
|
|
|
+ singleStatScenario('When value to text mapping is specified', (ctx: TestContext) => {
|
|
|
ctx.setup(() => {
|
|
ctx.setup(() => {
|
|
|
- ctx.data = tableData;
|
|
|
|
|
- ctx.data[0].rows[0] = [1492759673649, 'ignore1', 9.9, 'ignore2'];
|
|
|
|
|
|
|
+ ctx.input = tableData;
|
|
|
|
|
+ ctx.input[0].rows[0] = [1492759673649, 'ignore1', 9.9, 'ignore2'];
|
|
|
ctx.ctrl.panel.mappingType = 2;
|
|
ctx.ctrl.panel.mappingType = 2;
|
|
|
ctx.ctrl.panel.tableColumn = 'mean';
|
|
ctx.ctrl.panel.tableColumn = 'mean';
|
|
|
ctx.ctrl.panel.valueMaps = [{ value: '10', text: 'OK' }];
|
|
ctx.ctrl.panel.valueMaps = [{ value: '10', text: 'OK' }];
|
|
@@ -305,59 +301,60 @@ describe('SingleStatCtrl', () => {
|
|
|
expect(ctx.data.value).toBe(9.9);
|
|
expect(ctx.data.value).toBe(9.9);
|
|
|
});
|
|
});
|
|
|
|
|
|
|
|
- it('round should be rounded up', () => {
|
|
|
|
|
- expect(ctx.data.valueRounded).toBe(10);
|
|
|
|
|
- });
|
|
|
|
|
|
|
+ // it('round should be rounded up', () => {
|
|
|
|
|
+ // expect(ctx.data.valueRounded).toBe(10);
|
|
|
|
|
+ // });
|
|
|
|
|
|
|
|
it('Should replace value with text', () => {
|
|
it('Should replace value with text', () => {
|
|
|
- expect(ctx.data.valueFormatted).toBe('OK');
|
|
|
|
|
|
|
+ expect(ctx.data.display.text).toBe('OK');
|
|
|
});
|
|
});
|
|
|
});
|
|
});
|
|
|
|
|
|
|
|
- singleStatScenario('When range to text mapping is specified for first range', (ctx: any) => {
|
|
|
|
|
|
|
+ singleStatScenario('When range to text mapping is specified for first range', (ctx: TestContext) => {
|
|
|
ctx.setup(() => {
|
|
ctx.setup(() => {
|
|
|
- ctx.data = tableData;
|
|
|
|
|
- ctx.data[0].rows[0] = [1492759673649, 'ignore1', 41, 'ignore2'];
|
|
|
|
|
|
|
+ ctx.input = tableData;
|
|
|
|
|
+ ctx.input[0].rows[0] = [1492759673649, 'ignore1', 41, 'ignore2'];
|
|
|
ctx.ctrl.panel.tableColumn = 'mean';
|
|
ctx.ctrl.panel.tableColumn = 'mean';
|
|
|
ctx.ctrl.panel.mappingType = 2;
|
|
ctx.ctrl.panel.mappingType = 2;
|
|
|
ctx.ctrl.panel.rangeMaps = [{ from: '10', to: '50', text: 'OK' }, { from: '51', to: '100', text: 'NOT OK' }];
|
|
ctx.ctrl.panel.rangeMaps = [{ from: '10', to: '50', text: 'OK' }, { from: '51', to: '100', text: 'NOT OK' }];
|
|
|
});
|
|
});
|
|
|
|
|
|
|
|
it('Should replace value with text OK', () => {
|
|
it('Should replace value with text OK', () => {
|
|
|
- expect(ctx.data.valueFormatted).toBe('OK');
|
|
|
|
|
|
|
+ expect(ctx.data.display.text).toBe('OK');
|
|
|
});
|
|
});
|
|
|
});
|
|
});
|
|
|
|
|
|
|
|
- singleStatScenario('When range to text mapping is specified for other ranges', (ctx: any) => {
|
|
|
|
|
|
|
+ singleStatScenario('When range to text mapping is specified for other ranges', (ctx: TestContext) => {
|
|
|
ctx.setup(() => {
|
|
ctx.setup(() => {
|
|
|
- ctx.data = tableData;
|
|
|
|
|
- ctx.data[0].rows[0] = [1492759673649, 'ignore1', 65, 'ignore2'];
|
|
|
|
|
|
|
+ ctx.input = tableData;
|
|
|
|
|
+ ctx.input[0].rows[0] = [1492759673649, 'ignore1', 65, 'ignore2'];
|
|
|
ctx.ctrl.panel.tableColumn = 'mean';
|
|
ctx.ctrl.panel.tableColumn = 'mean';
|
|
|
ctx.ctrl.panel.mappingType = 2;
|
|
ctx.ctrl.panel.mappingType = 2;
|
|
|
ctx.ctrl.panel.rangeMaps = [{ from: '10', to: '50', text: 'OK' }, { from: '51', to: '100', text: 'NOT OK' }];
|
|
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', () => {
|
|
it('Should replace value with text NOT OK', () => {
|
|
|
- expect(ctx.data.valueFormatted).toBe('NOT OK');
|
|
|
|
|
|
|
+ expect(ctx.data.display.text).toBe('NOT OK');
|
|
|
});
|
|
});
|
|
|
});
|
|
});
|
|
|
|
|
|
|
|
- singleStatScenario('When value is string', (ctx: any) => {
|
|
|
|
|
|
|
+ singleStatScenario('When value is string', (ctx: TestContext) => {
|
|
|
ctx.setup(() => {
|
|
ctx.setup(() => {
|
|
|
- ctx.data = tableData;
|
|
|
|
|
- ctx.data[0].rows[0] = [1492759673649, 'ignore1', 65, 'ignore2'];
|
|
|
|
|
|
|
+ ctx.input = tableData;
|
|
|
|
|
+ ctx.input[0].rows[0] = [1492759673649, 'ignore1', 65, 'ignore2'];
|
|
|
ctx.ctrl.panel.tableColumn = 'test1';
|
|
ctx.ctrl.panel.tableColumn = 'test1';
|
|
|
|
|
+ ctx.ctrl.panel.valueName = ReducerID.first;
|
|
|
});
|
|
});
|
|
|
|
|
|
|
|
it('Should replace value with text NOT OK', () => {
|
|
it('Should replace value with text NOT OK', () => {
|
|
|
- expect(ctx.data.valueFormatted).toBe('ignore1');
|
|
|
|
|
|
|
+ expect(ctx.data.display.text).toBe('ignore1');
|
|
|
});
|
|
});
|
|
|
});
|
|
});
|
|
|
|
|
|
|
|
- singleStatScenario('When value is zero', (ctx: any) => {
|
|
|
|
|
|
|
+ singleStatScenario('When value is zero', (ctx: TestContext) => {
|
|
|
ctx.setup(() => {
|
|
ctx.setup(() => {
|
|
|
- ctx.data = tableData;
|
|
|
|
|
- ctx.data[0].rows[0] = [1492759673649, 'ignore1', 0, 'ignore2'];
|
|
|
|
|
|
|
+ ctx.input = tableData;
|
|
|
|
|
+ ctx.input[0].rows[0] = [1492759673649, 'ignore1', 0, 'ignore2'];
|
|
|
ctx.ctrl.panel.tableColumn = 'mean';
|
|
ctx.ctrl.panel.tableColumn = 'mean';
|
|
|
});
|
|
});
|
|
|
|
|
|