query-ctrl-specs.ts 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  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(angularMocks.module(function($compileProvider) {
  9. $compileProvider.preAssignBindingsEnabled(true);
  10. }));
  11. beforeEach(ctx.providePhase(['backendSrv','templateSrv']));
  12. beforeEach(ctx.providePhase());
  13. beforeEach(angularMocks.inject(($rootScope, $controller, $q) => {
  14. ctx.$q = $q;
  15. ctx.scope = $rootScope.$new();
  16. ctx.target = {target: ''};
  17. ctx.panelCtrl = {panel: {}};
  18. ctx.panelCtrl.refresh = sinon.spy();
  19. ctx.datasource.getAggregators = sinon.stub().returns(ctx.$q.when([]));
  20. ctx.datasource.getFilterTypes = sinon.stub().returns(ctx.$q.when([]));
  21. ctx.ctrl = $controller(OpenTsQueryCtrl, {$scope: ctx.scope}, {
  22. panelCtrl: ctx.panelCtrl,
  23. datasource: ctx.datasource,
  24. target: ctx.target,
  25. });
  26. ctx.scope.$digest();
  27. }));
  28. describe('init query_ctrl variables', function() {
  29. it('filter types should be initialized', function() {
  30. expect(ctx.ctrl.filterTypes.length).to.be(7);
  31. });
  32. it('aggregators should be initialized', function() {
  33. expect(ctx.ctrl.aggregators.length).to.be(8);
  34. });
  35. it('fill policy options should be initialized', function() {
  36. expect(ctx.ctrl.fillPolicies.length).to.be(4);
  37. });
  38. });
  39. describe('when adding filters and tags', function() {
  40. it('addTagMode should be false when closed', function() {
  41. ctx.ctrl.addTagMode = true;
  42. ctx.ctrl.closeAddTagMode();
  43. expect(ctx.ctrl.addTagMode).to.be(false);
  44. });
  45. it('addFilterMode should be false when closed', function() {
  46. ctx.ctrl.addFilterMode = true;
  47. ctx.ctrl.closeAddFilterMode();
  48. expect(ctx.ctrl.addFilterMode).to.be(false);
  49. });
  50. it('removing a tag from the tags list', function() {
  51. ctx.ctrl.target.tags = {"tagk": "tag_key", "tagk2": "tag_value2"};
  52. ctx.ctrl.removeTag("tagk");
  53. expect(Object.keys(ctx.ctrl.target.tags).length).to.be(1);
  54. });
  55. it('removing a filter from the filters list', function() {
  56. ctx.ctrl.target.filters = [{"tagk": "tag_key", "filter": "tag_value2", "type": "wildcard", "groupBy": true}];
  57. ctx.ctrl.removeFilter(0);
  58. expect(ctx.ctrl.target.filters.length).to.be(0);
  59. });
  60. it('adding a filter when tags exist should generate error', function() {
  61. ctx.ctrl.target.tags = {"tagk": "tag_key", "tagk2": "tag_value2"};
  62. ctx.ctrl.addFilter();
  63. expect(ctx.ctrl.errors.filters).to.be('Please remove tags to use filters, tags and filters are mutually exclusive.');
  64. });
  65. it('adding a tag when filters exist should generate error', function() {
  66. ctx.ctrl.target.filters = [{"tagk": "tag_key", "filter": "tag_value2", "type": "wildcard", "groupBy": true}];
  67. ctx.ctrl.addTag();
  68. expect(ctx.ctrl.errors.tags).to.be('Please remove filters to use tags, tags and filters are mutually exclusive.');
  69. });
  70. });
  71. });