renderer_specs.ts 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273
  1. ///<reference path="../../../../headers/common.d.ts" />
  2. import { describe, beforeEach, it, sinon, expect, angularMocks } from '../../../../../test/lib/common';
  3. import '../module';
  4. import angular from 'angular';
  5. import $ from 'jquery';
  6. import _ from 'lodash';
  7. import helpers from 'test/specs/helpers';
  8. import TimeSeries from 'app/core/time_series2';
  9. import moment from 'moment';
  10. import { Emitter } from 'app/core/core';
  11. import rendering from '../rendering';
  12. import {convertToHeatMap, convertToCards} from '../heatmap_data_converter';
  13. describe('grafanaHeatmap', function () {
  14. beforeEach(angularMocks.module('grafana.core'));
  15. function heatmapScenario(desc, func, elementWidth = 500) {
  16. describe(desc, function () {
  17. var ctx: any = {};
  18. ctx.setup = function (setupFunc) {
  19. beforeEach(angularMocks.module(function ($provide) {
  20. $provide.value("timeSrv", new helpers.TimeSrvStub());
  21. }));
  22. beforeEach(angularMocks.inject(function ($rootScope, $compile) {
  23. var ctrl: any = {
  24. colorSchemes: [
  25. {name: 'Oranges', value: 'interpolateOranges', invert: 'dark'},
  26. {name: 'Reds', value: 'interpolateReds', invert: 'dark'},
  27. ],
  28. events: new Emitter(),
  29. height: 200,
  30. panel: {
  31. heatmap: {
  32. },
  33. cards: {
  34. cardPadding: null,
  35. cardRound: null
  36. },
  37. color: {
  38. mode: 'spectrum',
  39. cardColor: '#b4ff00',
  40. colorScale: 'linear',
  41. exponent: 0.5,
  42. colorScheme: 'interpolateOranges',
  43. fillBackground: false
  44. },
  45. xBucketSize: 1000,
  46. xBucketNumber: null,
  47. yBucketSize: 1,
  48. yBucketNumber: null,
  49. xAxis: {
  50. show: true
  51. },
  52. yAxis: {
  53. show: true,
  54. format: 'short',
  55. decimals: null,
  56. logBase: 1,
  57. splitFactor: null,
  58. min: null,
  59. max: null,
  60. removeZeroValues: false
  61. },
  62. tooltip: {
  63. show: true,
  64. seriesStat: false,
  65. showHistogram: false
  66. },
  67. highlightCards: true
  68. },
  69. renderingCompleted: sinon.spy(),
  70. hiddenSeries: {},
  71. dashboard: {
  72. getTimezone: sinon.stub().returns('utc')
  73. },
  74. range: {
  75. from: moment.utc("01 Mar 2017 10:00:00", 'DD MMM YYYY HH:mm:ss'),
  76. to: moment.utc("01 Mar 2017 11:00:00", 'DD MMM YYYY HH:mm:ss'),
  77. },
  78. };
  79. var scope = $rootScope.$new();
  80. scope.ctrl = ctrl;
  81. ctx.series = [];
  82. ctx.series.push(new TimeSeries({
  83. datapoints: [[1, 1422774000000], [2, 1422774060000]],
  84. alias: 'series1'
  85. }));
  86. ctx.series.push(new TimeSeries({
  87. datapoints: [[2, 1422774000000], [3, 1422774060000]],
  88. alias: 'series2'
  89. }));
  90. ctx.data = {
  91. heatmapStats: {
  92. min: 1,
  93. max: 3,
  94. minLog: 1
  95. },
  96. xBucketSize: ctrl.panel.xBucketSize,
  97. yBucketSize: ctrl.panel.yBucketSize
  98. };
  99. setupFunc(ctrl, ctx);
  100. let logBase = ctrl.panel.yAxis.logBase;
  101. let bucketsData = convertToHeatMap(ctx.series, ctx.data.yBucketSize, ctx.data.xBucketSize, logBase);
  102. ctx.data.buckets = bucketsData;
  103. let cardsData = convertToCards(bucketsData);
  104. let maxCardsValue = _.max(_.map(cardsData, 'count'));
  105. let minCardsValue = _.min(_.map(cardsData, 'count'));
  106. let cardStats = {
  107. max: maxCardsValue,
  108. min: minCardsValue
  109. };
  110. ctx.data.cards = cardsData;
  111. ctx.data.cardStats = cardStats;
  112. let elemHtml = `
  113. <div class="heatmap-wrapper">
  114. <div class="heatmap-canvas-wrapper">
  115. <div class="heatmap-panel" style='width:${elementWidth}px'></div>
  116. </div>
  117. </div>`;
  118. var element = angular.element(elemHtml);
  119. $compile(element)(scope);
  120. scope.$digest();
  121. ctrl.data = ctx.data;
  122. ctx.element = element;
  123. let render = rendering(scope, $(element), [], ctrl);
  124. ctrl.events.emit('render');
  125. }));
  126. };
  127. func(ctx);
  128. });
  129. }
  130. heatmapScenario('default options', function (ctx) {
  131. ctx.setup(function (ctrl) {
  132. ctrl.panel.yAxis.logBase = 1;
  133. });
  134. it('should draw correct Y axis', function () {
  135. var yTicks = getTicks(ctx.element, ".axis-y");
  136. expect(yTicks).to.eql(['1', '2', '3']);
  137. });
  138. it('should draw correct X axis', function () {
  139. var xTicks = getTicks(ctx.element, ".axis-x");
  140. let expectedTicks = [
  141. formatTime("01 Mar 2017 10:00:00"),
  142. formatTime("01 Mar 2017 10:15:00"),
  143. formatTime("01 Mar 2017 10:30:00"),
  144. formatTime("01 Mar 2017 10:45:00"),
  145. formatTime("01 Mar 2017 11:00:00")
  146. ];
  147. expect(xTicks).to.eql(expectedTicks);
  148. });
  149. });
  150. heatmapScenario('when logBase is 2', function (ctx) {
  151. ctx.setup(function (ctrl) {
  152. ctrl.panel.yAxis.logBase = 2;
  153. });
  154. it('should draw correct Y axis', function () {
  155. var yTicks = getTicks(ctx.element, ".axis-y");
  156. expect(yTicks).to.eql(['1', '2', '4']);
  157. });
  158. });
  159. heatmapScenario('when logBase is 10', function (ctx) {
  160. ctx.setup(function (ctrl, ctx) {
  161. ctrl.panel.yAxis.logBase = 10;
  162. ctx.series.push(new TimeSeries({
  163. datapoints: [[10, 1422774000000], [20, 1422774060000]],
  164. alias: 'series3'
  165. }));
  166. ctx.data.heatmapStats.max = 20;
  167. });
  168. it('should draw correct Y axis', function () {
  169. var yTicks = getTicks(ctx.element, ".axis-y");
  170. expect(yTicks).to.eql(['1', '10', '100']);
  171. });
  172. });
  173. heatmapScenario('when logBase is 32', function (ctx) {
  174. ctx.setup(function (ctrl) {
  175. ctrl.panel.yAxis.logBase = 32;
  176. ctx.series.push(new TimeSeries({
  177. datapoints: [[10, 1422774000000], [100, 1422774060000]],
  178. alias: 'series3'
  179. }));
  180. ctx.data.heatmapStats.max = 100;
  181. });
  182. it('should draw correct Y axis', function () {
  183. var yTicks = getTicks(ctx.element, ".axis-y");
  184. expect(yTicks).to.eql(['1', '32', '1.0 K']);
  185. });
  186. });
  187. heatmapScenario('when logBase is 1024', function (ctx) {
  188. ctx.setup(function (ctrl) {
  189. ctrl.panel.yAxis.logBase = 1024;
  190. ctx.series.push(new TimeSeries({
  191. datapoints: [[2000, 1422774000000], [300000, 1422774060000]],
  192. alias: 'series3'
  193. }));
  194. ctx.data.heatmapStats.max = 300000;
  195. });
  196. it('should draw correct Y axis', function () {
  197. var yTicks = getTicks(ctx.element, ".axis-y");
  198. expect(yTicks).to.eql(['1', '1 K', '1.0 Mil']);
  199. });
  200. });
  201. heatmapScenario('when Y axis format set to "none"', function (ctx) {
  202. ctx.setup(function (ctrl) {
  203. ctrl.panel.yAxis.logBase = 1;
  204. ctrl.panel.yAxis.format = "none";
  205. ctx.data.heatmapStats.max = 10000;
  206. });
  207. it('should draw correct Y axis', function () {
  208. var yTicks = getTicks(ctx.element, ".axis-y");
  209. expect(yTicks).to.eql(['0', '2000', '4000', '6000', '8000', '10000', '12000']);
  210. });
  211. });
  212. heatmapScenario('when Y axis format set to "second"', function (ctx) {
  213. ctx.setup(function (ctrl) {
  214. ctrl.panel.yAxis.logBase = 1;
  215. ctrl.panel.yAxis.format = "s";
  216. ctx.data.heatmapStats.max = 3600;
  217. });
  218. it('should draw correct Y axis', function () {
  219. var yTicks = getTicks(ctx.element, ".axis-y");
  220. expect(yTicks).to.eql(['0 ns', '17 min', '33 min', '50 min', '1.11 hour']);
  221. });
  222. });
  223. });
  224. function getTicks(element, axisSelector) {
  225. return element.find(axisSelector).find("text")
  226. .map(function () {
  227. return this.textContent;
  228. }).get();
  229. }
  230. function formatTime(timeStr) {
  231. let format = "HH:mm";
  232. return moment.utc(timeStr, 'DD MMM YYYY HH:mm:ss').format(format);
  233. }