time_series_specs.js 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154
  1. define([
  2. 'app/core/time_series'
  3. ], function(TimeSeries) {
  4. 'use strict';
  5. describe("TimeSeries", function() {
  6. var points, series;
  7. var yAxisFormats = ['short', 'ms'];
  8. var testData = {
  9. alias: 'test',
  10. datapoints: [
  11. [1,2],[null,3],[10,4],[8,5]
  12. ]
  13. };
  14. describe('when getting flot pairs', function() {
  15. it('with connected style, should ignore nulls', function() {
  16. series = new TimeSeries(testData);
  17. points = series.getFlotPairs('connected', yAxisFormats);
  18. expect(points.length).to.be(3);
  19. });
  20. it('with null as zero style, should replace nulls with zero', function() {
  21. series = new TimeSeries(testData);
  22. points = series.getFlotPairs('null as zero', yAxisFormats);
  23. expect(points.length).to.be(4);
  24. expect(points[1][1]).to.be(0);
  25. });
  26. it('if last is null current should pick next to last', function() {
  27. series = new TimeSeries({
  28. datapoints: [[10,1], [null, 2]]
  29. });
  30. series.getFlotPairs('null', yAxisFormats);
  31. expect(series.stats.current).to.be(10);
  32. });
  33. it('max value should work for negative values', function() {
  34. series = new TimeSeries({
  35. datapoints: [[-10,1], [-4, 2]]
  36. });
  37. series.getFlotPairs('null', yAxisFormats);
  38. expect(series.stats.max).to.be(-4);
  39. });
  40. it('average value should ignore nulls', function() {
  41. series = new TimeSeries(testData);
  42. series.getFlotPairs('null', yAxisFormats);
  43. expect(series.stats.avg).to.be(6.333333333333333);
  44. });
  45. it('with null as zero style, average value should treat nulls as 0', function() {
  46. series = new TimeSeries(testData);
  47. series.getFlotPairs('null as zero', yAxisFormats);
  48. expect(series.stats.avg).to.be(4.75);
  49. });
  50. });
  51. describe('series overrides', function() {
  52. var series;
  53. beforeEach(function() {
  54. series = new TimeSeries(testData);
  55. });
  56. describe('fill & points', function() {
  57. beforeEach(function() {
  58. series.alias = 'test';
  59. series.applySeriesOverrides([{ alias: 'test', fill: 0, points: true }]);
  60. });
  61. it('should set fill zero, and enable points', function() {
  62. expect(series.lines.fill).to.be(0.001);
  63. expect(series.points.show).to.be(true);
  64. });
  65. });
  66. describe('series option overrides, bars, true & lines false', function() {
  67. beforeEach(function() {
  68. series.alias = 'test';
  69. series.applySeriesOverrides([{ alias: 'test', bars: true, lines: false }]);
  70. });
  71. it('should disable lines, and enable bars', function() {
  72. expect(series.lines.show).to.be(false);
  73. expect(series.bars.show).to.be(true);
  74. });
  75. });
  76. describe('series option overrides, linewidth, stack', function() {
  77. beforeEach(function() {
  78. series.alias = 'test';
  79. series.applySeriesOverrides([{ alias: 'test', linewidth: 5, stack: false }]);
  80. });
  81. it('should disable stack, and set lineWidth', function() {
  82. expect(series.stack).to.be(false);
  83. expect(series.lines.lineWidth).to.be(5);
  84. });
  85. });
  86. describe('series option overrides, fill below to', function() {
  87. beforeEach(function() {
  88. series.alias = 'test';
  89. series.applySeriesOverrides([{ alias: 'test', fillBelowTo: 'min' }]);
  90. });
  91. it('should disable line fill and add fillBelowTo', function() {
  92. expect(series.fillBelowTo).to.be('min');
  93. });
  94. });
  95. describe('series option overrides, pointradius, steppedLine', function() {
  96. beforeEach(function() {
  97. series.alias = 'test';
  98. series.applySeriesOverrides([{ alias: 'test', pointradius: 5, steppedLine: true }]);
  99. });
  100. it('should set pointradius, and set steppedLine', function() {
  101. expect(series.points.radius).to.be(5);
  102. expect(series.lines.steps).to.be(true);
  103. });
  104. });
  105. describe('override match on regex', function() {
  106. beforeEach(function() {
  107. series.alias = 'test_01';
  108. series.applySeriesOverrides([{ alias: '/.*01/', lines: false }]);
  109. });
  110. it('should match second series', function() {
  111. expect(series.lines.show).to.be(false);
  112. });
  113. });
  114. describe('override series y-axis, and z-index', function() {
  115. beforeEach(function() {
  116. series.alias = 'test';
  117. series.applySeriesOverrides([{ alias: 'test', yaxis: 2, zindex: 2 }]);
  118. });
  119. it('should set yaxis', function() {
  120. expect(series.yaxis).to.be(2);
  121. });
  122. it('should set zindex', function() {
  123. expect(series.zindex).to.be(2);
  124. });
  125. });
  126. });
  127. });
  128. });