| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204 |
- define([
- 'app/core/time_series'
- ], function(TimeSeries) {
- 'use strict';
- describe("TimeSeries", function() {
- var points, series;
- var yAxisFormats = ['short', 'ms'];
- var testData = {
- alias: 'test',
- datapoints: [
- [1,2],[null,3],[10,4],[8,5]
- ]
- };
- describe('when getting flot pairs', function() {
- it('with connected style, should ignore nulls', function() {
- series = new TimeSeries(testData);
- points = series.getFlotPairs('connected', yAxisFormats);
- expect(points.length).to.be(3);
- });
- it('with null as zero style, should replace nulls with zero', function() {
- series = new TimeSeries(testData);
- points = series.getFlotPairs('null as zero', yAxisFormats);
- expect(points.length).to.be(4);
- expect(points[1][1]).to.be(0);
- });
- it('if last is null current should pick next to last', function() {
- series = new TimeSeries({
- datapoints: [[10,1], [null, 2]]
- });
- series.getFlotPairs('null', yAxisFormats);
- expect(series.stats.current).to.be(10);
- });
- it('max value should work for negative values', function() {
- series = new TimeSeries({
- datapoints: [[-10,1], [-4, 2]]
- });
- series.getFlotPairs('null', yAxisFormats);
- expect(series.stats.max).to.be(-4);
- });
- it('average value should ignore nulls', function() {
- series = new TimeSeries(testData);
- series.getFlotPairs('null', yAxisFormats);
- expect(series.stats.avg).to.be(6.333333333333333);
- });
- it('with null as zero style, average value should treat nulls as 0', function() {
- series = new TimeSeries(testData);
- series.getFlotPairs('null as zero', yAxisFormats);
- expect(series.stats.avg).to.be(4.75);
- });
- });
- describe('When checking if ms resolution is needed', function() {
- describe('msResolution with second resolution timestamps', function() {
- beforeEach(function() {
- series = new TimeSeries({datapoints: [[45, 1234567890], [60, 1234567899]]});
- });
- it('should set hasMsResolution to false', function() {
- expect(series.hasMsResolution).to.be(false);
- });
- });
- describe('msResolution with millisecond resolution timestamps', function() {
- beforeEach(function() {
- series = new TimeSeries({datapoints: [[55, 1236547890001], [90, 1234456709000]]});
- });
- it('should show millisecond resolution tooltip', function() {
- expect(series.hasMsResolution).to.be(true);
- });
- });
- describe('msResolution with millisecond resolution timestamps but with trailing zeroes', function() {
- beforeEach(function() {
- series = new TimeSeries({datapoints: [[45, 1234567890000], [60, 1234567899000]]});
- });
- it('should not show millisecond resolution tooltip', function() {
- expect(series.hasMsResolution).to.be(false);
- });
- });
- });
- describe('can detect if series contains ms precision', function() {
- var fakedata;
- beforeEach(function() {
- fakedata = testData;
- });
- it('missing datapoint with ms precision', function() {
- fakedata.datapoints[0] = [1337, 1234567890000];
- series = new TimeSeries(fakedata);
- expect(series.isMsResolutionNeeded()).to.be(false);
- });
- it('contains datapoint with ms precision', function() {
- fakedata.datapoints[0] = [1337, 1236547890001];
- series = new TimeSeries(fakedata);
- expect(series.isMsResolutionNeeded()).to.be(true);
- });
- });
- describe('series overrides', function() {
- var series;
- beforeEach(function() {
- series = new TimeSeries(testData);
- });
- describe('fill & points', function() {
- beforeEach(function() {
- series.alias = 'test';
- series.applySeriesOverrides([{ alias: 'test', fill: 0, points: true }]);
- });
- it('should set fill zero, and enable points', function() {
- expect(series.lines.fill).to.be(0.001);
- expect(series.points.show).to.be(true);
- });
- });
- describe('series option overrides, bars, true & lines false', function() {
- beforeEach(function() {
- series.alias = 'test';
- series.applySeriesOverrides([{ alias: 'test', bars: true, lines: false }]);
- });
- it('should disable lines, and enable bars', function() {
- expect(series.lines.show).to.be(false);
- expect(series.bars.show).to.be(true);
- });
- });
- describe('series option overrides, linewidth, stack', function() {
- beforeEach(function() {
- series.alias = 'test';
- series.applySeriesOverrides([{ alias: 'test', linewidth: 5, stack: false }]);
- });
- it('should disable stack, and set lineWidth', function() {
- expect(series.stack).to.be(false);
- expect(series.lines.lineWidth).to.be(5);
- });
- });
- describe('series option overrides, fill below to', function() {
- beforeEach(function() {
- series.alias = 'test';
- series.applySeriesOverrides([{ alias: 'test', fillBelowTo: 'min' }]);
- });
- it('should disable line fill and add fillBelowTo', function() {
- expect(series.fillBelowTo).to.be('min');
- });
- });
- describe('series option overrides, pointradius, steppedLine', function() {
- beforeEach(function() {
- series.alias = 'test';
- series.applySeriesOverrides([{ alias: 'test', pointradius: 5, steppedLine: true }]);
- });
- it('should set pointradius, and set steppedLine', function() {
- expect(series.points.radius).to.be(5);
- expect(series.lines.steps).to.be(true);
- });
- });
- describe('override match on regex', function() {
- beforeEach(function() {
- series.alias = 'test_01';
- series.applySeriesOverrides([{ alias: '/.*01/', lines: false }]);
- });
- it('should match second series', function() {
- expect(series.lines.show).to.be(false);
- });
- });
- describe('override series y-axis, and z-index', function() {
- beforeEach(function() {
- series.alias = 'test';
- series.applySeriesOverrides([{ alias: 'test', yaxis: 2, zindex: 2 }]);
- });
- it('should set yaxis', function() {
- expect(series.yaxis).to.be(2);
- });
- it('should set zindex', function() {
- expect(series.zindex).to.be(2);
- });
- });
- });
- });
- });
|