renderer.jest.ts 9.5 KB

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