mirror of https://github.com/grafana/grafana
parent
936dd2eaaa
commit
4aa5dab62d
@ -0,0 +1,85 @@ |
||||
import {describe, beforeEach, it, sinon, expect, angularMocks} from 'test/lib/common'; |
||||
import helpers from 'test/specs/helpers'; |
||||
import {OpenTsQueryCtrl} from "../query_ctrl"; |
||||
|
||||
describe('OpenTsQueryCtrl', function() { |
||||
var ctx = new helpers.ControllerTestContext(); |
||||
|
||||
beforeEach(angularMocks.module('grafana.core')); |
||||
beforeEach(angularMocks.module('grafana.services')); |
||||
beforeEach(ctx.providePhase(['backendSrv','templateSrv'])); |
||||
|
||||
beforeEach(ctx.providePhase()); |
||||
beforeEach(angularMocks.inject(($rootScope, $controller, $q) => { |
||||
ctx.$q = $q; |
||||
ctx.scope = $rootScope.$new(); |
||||
ctx.target = {target: ''}; |
||||
ctx.panelCtrl = {panel: {}}; |
||||
ctx.panelCtrl.refresh = sinon.spy(); |
||||
ctx.datasource.getAggregators = sinon.stub().returns(ctx.$q.when([])); |
||||
|
||||
ctx.ctrl = $controller(OpenTsQueryCtrl, {$scope: ctx.scope}, { |
||||
panelCtrl: ctx.panelCtrl, |
||||
datasource: ctx.datasource, |
||||
target: ctx.target, |
||||
}); |
||||
ctx.scope.$digest(); |
||||
})); |
||||
|
||||
describe('init query_ctrl variables', function() { |
||||
|
||||
it('filter types should be initialized', function() { |
||||
expect(ctx.ctrl.filterTypes.length).to.be(7); |
||||
}); |
||||
|
||||
it('aggregators should be initialized', function() { |
||||
expect(ctx.ctrl.aggregators.length).to.be(8); |
||||
}); |
||||
|
||||
it('fill policy options should be initialized', function() { |
||||
expect(ctx.ctrl.fillPolicies.length).to.be(4); |
||||
}); |
||||
|
||||
}); |
||||
|
||||
describe('when adding filters and tags', function() { |
||||
|
||||
it('addTagMode should be false when closed', function() { |
||||
ctx.ctrl.addTagMode = true; |
||||
ctx.ctrl.closeAddTagMode(); |
||||
expect(ctx.ctrl.addTagMode).to.be(false); |
||||
}); |
||||
|
||||
it('addFilterMode should be false when closed', function() { |
||||
ctx.ctrl.addFilterMode = true; |
||||
ctx.ctrl.closeAddFilterMode(); |
||||
expect(ctx.ctrl.addFilterMode).to.be(false); |
||||
}); |
||||
|
||||
it('removing a tag from the tags list', function() { |
||||
ctx.ctrl.target.tags = {"tagk": "tag_key", "tagk2": "tag_value2"}; |
||||
ctx.ctrl.removeTag("tagk"); |
||||
expect(Object.keys(ctx.ctrl.target.tags).length).to.be(1); |
||||
}); |
||||
|
||||
it('removing a filter from the filters list', function() { |
||||
ctx.ctrl.target.filters = [{"tagk": "tag_key", "filter": "tag_value2", "type": "wildcard", "groupBy": true}]; |
||||
ctx.ctrl.removeFilter(0); |
||||
expect(ctx.ctrl.target.filters.length).to.be(0); |
||||
}); |
||||
|
||||
it('adding a filter when tags exist should generate error', function() { |
||||
ctx.ctrl.target.tags = {"tagk": "tag_key", "tagk2": "tag_value2"}; |
||||
ctx.ctrl.addFilter(); |
||||
expect(ctx.ctrl.errors.filters).to.be('Please remove tags to use filters, tags and filters are mutually exclusive.'); |
||||
}); |
||||
|
||||
it('adding a tag when filters exist should generate error', function() { |
||||
ctx.ctrl.target.filters = [{"tagk": "tag_key", "filter": "tag_value2", "type": "wildcard", "groupBy": true}]; |
||||
ctx.ctrl.addTag(); |
||||
expect(ctx.ctrl.errors.tags).to.be('Please remove filters to use tags, tags and filters are mutually exclusive.'); |
||||
}); |
||||
|
||||
}); |
||||
|
||||
}); |
Loading…
Reference in new issue