| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380 |
- import TimeSeries from 'app/core/time_series2';
- import { updateLegendValues } from 'app/core/time_series2';
- describe('TimeSeries', () => {
- let points, series: any;
- const yAxisFormats = ['short', 'ms'];
- let testData: { alias?: string; datapoints: any };
- beforeEach(() => {
- testData = {
- alias: 'test',
- datapoints: [[1, 2], [null, 3], [10, 4], [8, 5]],
- };
- });
- describe('when getting flot pairs', () => {
- it('with connected style, should ignore nulls', () => {
- series = new TimeSeries(testData);
- points = series.getFlotPairs('connected', yAxisFormats);
- expect(points.length).toBe(3);
- });
- it('with null as zero style, should replace nulls with zero', () => {
- series = new TimeSeries(testData);
- points = series.getFlotPairs('null as zero', yAxisFormats);
- expect(points.length).toBe(4);
- expect(points[1][1]).toBe(0);
- });
- it('if last is null current should pick next to last', () => {
- series = new TimeSeries({
- datapoints: [[10, 1], [null, 2]],
- });
- series.getFlotPairs('null', yAxisFormats);
- expect(series.stats.current).toBe(10);
- });
- it('max value should work for negative values', () => {
- series = new TimeSeries({
- datapoints: [[-10, 1], [-4, 2]],
- });
- series.getFlotPairs('null', yAxisFormats);
- expect(series.stats.max).toBe(-4);
- });
- it('average value should ignore nulls', () => {
- series = new TimeSeries(testData);
- series.getFlotPairs('null', yAxisFormats);
- expect(series.stats.avg).toBe(6.333333333333333);
- });
- it('the delta value should account for nulls', () => {
- series = new TimeSeries({
- datapoints: [[1, 2], [3, 3], [null, 4], [10, 5], [15, 6]],
- });
- series.getFlotPairs('null', yAxisFormats);
- expect(series.stats.delta).toBe(14);
- });
- it('the delta value should account for nulls on first', () => {
- series = new TimeSeries({
- datapoints: [[null, 2], [1, 3], [10, 4], [15, 5]],
- });
- series.getFlotPairs('null', yAxisFormats);
- expect(series.stats.delta).toBe(14);
- });
- it('the delta value should account for nulls on last', () => {
- series = new TimeSeries({
- datapoints: [[1, 2], [5, 3], [10, 4], [null, 5]],
- });
- series.getFlotPairs('null', yAxisFormats);
- expect(series.stats.delta).toBe(9);
- });
- it('the delta value should account for resets', () => {
- series = new TimeSeries({
- datapoints: [[1, 2], [5, 3], [10, 4], [0, 5], [10, 6]],
- });
- series.getFlotPairs('null', yAxisFormats);
- expect(series.stats.delta).toBe(19);
- });
- it('the delta value should account for resets on last', () => {
- series = new TimeSeries({
- datapoints: [[1, 2], [2, 3], [10, 4], [8, 5]],
- });
- series.getFlotPairs('null', yAxisFormats);
- expect(series.stats.delta).toBe(17);
- });
- it('the range value should be max - min', () => {
- series = new TimeSeries(testData);
- series.getFlotPairs('null', yAxisFormats);
- expect(series.stats.range).toBe(9);
- });
- it('first value should ingone nulls', () => {
- series = new TimeSeries(testData);
- series.getFlotPairs('null', yAxisFormats);
- expect(series.stats.first).toBe(1);
- series = new TimeSeries({
- datapoints: [[null, 2], [1, 3], [10, 4], [8, 5]],
- });
- series.getFlotPairs('null', yAxisFormats);
- expect(series.stats.first).toBe(1);
- });
- it('with null as zero style, average value should treat nulls as 0', () => {
- series = new TimeSeries(testData);
- series.getFlotPairs('null as zero', yAxisFormats);
- expect(series.stats.avg).toBe(4.75);
- });
- it('average value should be null if all values is null', () => {
- series = new TimeSeries({
- datapoints: [[null, 2], [null, 3], [null, 4], [null, 5]],
- });
- series.getFlotPairs('null');
- expect(series.stats.avg).toBe(null);
- });
- it('calculates timeStep', () => {
- series = new TimeSeries({
- datapoints: [[null, 1], [null, 2], [null, 3]],
- });
- series.getFlotPairs('null');
- expect(series.stats.timeStep).toBe(1);
- series = new TimeSeries({
- datapoints: [[0, 1530529290], [0, 1530529305], [0, 1530529320]],
- });
- series.getFlotPairs('null');
- expect(series.stats.timeStep).toBe(15);
- });
- });
- describe('When checking if ms resolution is needed', () => {
- describe('msResolution with second resolution timestamps', () => {
- beforeEach(() => {
- series = new TimeSeries({
- datapoints: [[45, 1234567890], [60, 1234567899]],
- });
- });
- it('should set hasMsResolution to false', () => {
- expect(series.hasMsResolution).toBe(false);
- });
- });
- describe('msResolution with millisecond resolution timestamps', () => {
- beforeEach(() => {
- series = new TimeSeries({
- datapoints: [[55, 1236547890001], [90, 1234456709000]],
- });
- });
- it('should show millisecond resolution tooltip', () => {
- expect(series.hasMsResolution).toBe(true);
- });
- });
- describe('msResolution with millisecond resolution timestamps but with trailing zeroes', () => {
- beforeEach(() => {
- series = new TimeSeries({
- datapoints: [[45, 1234567890000], [60, 1234567899000]],
- });
- });
- it('should not show millisecond resolution tooltip', () => {
- expect(series.hasMsResolution).toBe(false);
- });
- });
- });
- describe('can detect if series contains ms precision', () => {
- let fakedata: any;
- beforeEach(() => {
- fakedata = testData;
- });
- it('missing datapoint with ms precision', () => {
- fakedata.datapoints[0] = [1337, 1234567890000];
- series = new TimeSeries(fakedata);
- expect(series.isMsResolutionNeeded()).toBe(false);
- });
- it('contains datapoint with ms precision', () => {
- fakedata.datapoints[0] = [1337, 1236547890001];
- series = new TimeSeries(fakedata);
- expect(series.isMsResolutionNeeded()).toBe(true);
- });
- });
- describe('series overrides', () => {
- let series: any;
- beforeEach(() => {
- series = new TimeSeries(testData);
- });
- describe('fill & points', () => {
- beforeEach(() => {
- series.alias = 'test';
- series.applySeriesOverrides([{ alias: 'test', fill: 0, points: true }]);
- });
- it('should set fill zero, and enable points', () => {
- expect(series.lines.fill).toBe(0.001);
- expect(series.points.show).toBe(true);
- });
- });
- describe('series option overrides, bars, true & lines false', () => {
- beforeEach(() => {
- series.alias = 'test';
- series.applySeriesOverrides([{ alias: 'test', bars: true, lines: false }]);
- });
- it('should disable lines, and enable bars', () => {
- expect(series.lines.show).toBe(false);
- expect(series.bars.show).toBe(true);
- });
- });
- describe('series option overrides, linewidth, stack', () => {
- beforeEach(() => {
- series.alias = 'test';
- series.applySeriesOverrides([{ alias: 'test', linewidth: 5, stack: false }]);
- });
- it('should disable stack, and set lineWidth', () => {
- expect(series.stack).toBe(false);
- expect(series.lines.lineWidth).toBe(5);
- });
- });
- describe('series option overrides, dashes and lineWidth', () => {
- beforeEach(() => {
- series.alias = 'test';
- series.applySeriesOverrides([{ alias: 'test', linewidth: 5, dashes: true }]);
- });
- it('should enable dashes, set dashes lineWidth to 5 and lines lineWidth to 0', () => {
- expect(series.dashes.show).toBe(true);
- expect(series.dashes.lineWidth).toBe(5);
- expect(series.lines.lineWidth).toBe(0);
- });
- });
- describe('series option overrides, fill below to', () => {
- beforeEach(() => {
- series.alias = 'test';
- series.applySeriesOverrides([{ alias: 'test', fillBelowTo: 'min' }]);
- });
- it('should disable line fill and add fillBelowTo', () => {
- expect(series.fillBelowTo).toBe('min');
- });
- });
- describe('series option overrides, pointradius, steppedLine', () => {
- beforeEach(() => {
- series.alias = 'test';
- series.applySeriesOverrides([{ alias: 'test', pointradius: 5, steppedLine: true }]);
- });
- it('should set pointradius, and set steppedLine', () => {
- expect(series.points.radius).toBe(5);
- expect(series.lines.steps).toBe(true);
- });
- });
- describe('override match on regex', () => {
- beforeEach(() => {
- series.alias = 'test_01';
- series.applySeriesOverrides([{ alias: '/.*01/', lines: false }]);
- });
- it('should match second series', () => {
- expect(series.lines.show).toBe(false);
- });
- });
- describe('override series y-axis, and z-index', () => {
- beforeEach(() => {
- series.alias = 'test';
- series.applySeriesOverrides([{ alias: 'test', yaxis: 2, zindex: 2 }]);
- });
- it('should set yaxis', () => {
- expect(series.yaxis).toBe(2);
- });
- it('should set zindex', () => {
- expect(series.zindex).toBe(2);
- });
- });
- describe('override color', () => {
- beforeEach(() => {
- series.applySeriesOverrides([{ alias: 'test', color: '#112233' }]);
- });
- it('should set color', () => {
- expect(series.color).toBe('#112233');
- });
- it('should set bars.fillColor', () => {
- expect(series.bars.fillColor).toBe('#112233');
- });
- });
- });
- describe('value formatter', () => {
- let series: any;
- beforeEach(() => {
- series = new TimeSeries(testData);
- });
- it('should format non-numeric values as empty string', () => {
- expect(series.formatValue(null)).toBe('');
- expect(series.formatValue(undefined)).toBe('');
- expect(series.formatValue(NaN)).toBe('');
- expect(series.formatValue(Infinity)).toBe('');
- expect(series.formatValue(-Infinity)).toBe('');
- });
- });
- describe('legend decimals', () => {
- let series: any, panel: any;
- const height = 200;
- beforeEach(() => {
- testData = {
- alias: 'test',
- datapoints: [[1, 2], [0, 3], [10, 4], [8, 5]],
- };
- series = new TimeSeries(testData);
- series.getFlotPairs();
- panel = {
- decimals: null,
- yaxes: [
- {
- decimals: null,
- },
- ],
- };
- });
- it('should set decimals based on Y axis (expect calculated decimals = 1)', () => {
- const data = [series];
- // Expect ticks with this data will have decimals = 1
- updateLegendValues(data, panel, height);
- expect(data[0].decimals).toBe(2);
- });
- it('should set decimals based on Y axis to 0 if calculated decimals = 0)', () => {
- testData.datapoints = [[10, 2], [0, 3], [100, 4], [80, 5]];
- series = new TimeSeries(testData);
- series.getFlotPairs();
- const data = [series];
- updateLegendValues(data, panel, height);
- expect(data[0].decimals).toBe(0);
- });
- it('should set decimals to Y axis decimals + 1', () => {
- panel.yaxes[0].decimals = 2;
- const data = [series];
- updateLegendValues(data, panel, height);
- expect(data[0].decimals).toBe(3);
- });
- it('should set decimals to legend decimals value if it was set explicitly', () => {
- panel.decimals = 3;
- const data = [series];
- updateLegendValues(data, panel, height);
- expect(data[0].decimals).toBe(3);
- });
- });
- });
|