query-ctrl-specs.ts 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. import { describe, beforeEach, it, sinon, expect, angularMocks } from 'test/lib/common';
  2. import helpers from 'test/specs/helpers';
  3. import { OpenTsQueryCtrl } from '../query_ctrl';
  4. describe('OpenTsQueryCtrl', function() {
  5. var ctx = new helpers.ControllerTestContext();
  6. beforeEach(angularMocks.module('grafana.core'));
  7. beforeEach(angularMocks.module('grafana.services'));
  8. beforeEach(
  9. angularMocks.module(function($compileProvider) {
  10. $compileProvider.preAssignBindingsEnabled(true);
  11. })
  12. );
  13. beforeEach(ctx.providePhase(['backendSrv', 'templateSrv']));
  14. beforeEach(ctx.providePhase());
  15. beforeEach(
  16. angularMocks.inject(($rootScope, $controller, $q) => {
  17. ctx.$q = $q;
  18. ctx.scope = $rootScope.$new();
  19. ctx.target = { target: '' };
  20. ctx.panelCtrl = {
  21. panel: {
  22. targets: [ctx.target],
  23. },
  24. };
  25. ctx.panelCtrl.refresh = sinon.spy();
  26. ctx.datasource.getAggregators = sinon.stub().returns(ctx.$q.when([]));
  27. ctx.datasource.getFilterTypes = sinon.stub().returns(ctx.$q.when([]));
  28. ctx.ctrl = $controller(
  29. OpenTsQueryCtrl,
  30. { $scope: ctx.scope },
  31. {
  32. panelCtrl: ctx.panelCtrl,
  33. datasource: ctx.datasource,
  34. target: ctx.target,
  35. }
  36. );
  37. ctx.scope.$digest();
  38. })
  39. );
  40. describe('init query_ctrl variables', function() {
  41. it('filter types should be initialized', function() {
  42. expect(ctx.ctrl.filterTypes.length).to.be(7);
  43. });
  44. it('aggregators should be initialized', function() {
  45. expect(ctx.ctrl.aggregators.length).to.be(8);
  46. });
  47. it('fill policy options should be initialized', function() {
  48. expect(ctx.ctrl.fillPolicies.length).to.be(4);
  49. });
  50. });
  51. describe('when adding filters and tags', function() {
  52. it('addTagMode should be false when closed', function() {
  53. ctx.ctrl.addTagMode = true;
  54. ctx.ctrl.closeAddTagMode();
  55. expect(ctx.ctrl.addTagMode).to.be(false);
  56. });
  57. it('addFilterMode should be false when closed', function() {
  58. ctx.ctrl.addFilterMode = true;
  59. ctx.ctrl.closeAddFilterMode();
  60. expect(ctx.ctrl.addFilterMode).to.be(false);
  61. });
  62. it('removing a tag from the tags list', function() {
  63. ctx.ctrl.target.tags = { tagk: 'tag_key', tagk2: 'tag_value2' };
  64. ctx.ctrl.removeTag('tagk');
  65. expect(Object.keys(ctx.ctrl.target.tags).length).to.be(1);
  66. });
  67. it('removing a filter from the filters list', function() {
  68. ctx.ctrl.target.filters = [
  69. {
  70. tagk: 'tag_key',
  71. filter: 'tag_value2',
  72. type: 'wildcard',
  73. groupBy: true,
  74. },
  75. ];
  76. ctx.ctrl.removeFilter(0);
  77. expect(ctx.ctrl.target.filters.length).to.be(0);
  78. });
  79. it('adding a filter when tags exist should generate error', function() {
  80. ctx.ctrl.target.tags = { tagk: 'tag_key', tagk2: 'tag_value2' };
  81. ctx.ctrl.addFilter();
  82. expect(ctx.ctrl.errors.filters).to.be(
  83. 'Please remove tags to use filters, tags and filters are mutually exclusive.'
  84. );
  85. });
  86. it('adding a tag when filters exist should generate error', function() {
  87. ctx.ctrl.target.filters = [
  88. {
  89. tagk: 'tag_key',
  90. filter: 'tag_value2',
  91. type: 'wildcard',
  92. groupBy: true,
  93. },
  94. ];
  95. ctx.ctrl.addTag();
  96. expect(ctx.ctrl.errors.tags).to.be('Please remove filters to use tags, tags and filters are mutually exclusive.');
  97. });
  98. });
  99. });