opentsdbDatasource-specs.js 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. define([
  2. './helpers',
  3. 'app/plugins/datasource/opentsdb/datasource'
  4. ], function(helpers) {
  5. 'use strict';
  6. describe('opentsdb', function() {
  7. var ctx = new helpers.ServiceTestContext();
  8. beforeEach(module('grafana.core'));
  9. beforeEach(module('grafana.services'));
  10. beforeEach(ctx.providePhase(['backendSrv']));
  11. beforeEach(ctx.createService('OpenTSDBDatasource'));
  12. beforeEach(function() {
  13. ctx.ds = new ctx.service({ url: [''] });
  14. });
  15. describe('When performing metricFindQuery', function() {
  16. var results;
  17. var requestOptions;
  18. beforeEach(function() {
  19. ctx.backendSrv.datasourceRequest = function(options) {
  20. requestOptions = options;
  21. return ctx.$q.when({data: [{ target: 'prod1.count', datapoints: [[10, 1], [12,1]] }]});
  22. };
  23. });
  24. it('metrics() should generate api suggest query', function() {
  25. ctx.ds.metricFindQuery('metrics()').then(function(data) { results = data; });
  26. ctx.$rootScope.$apply();
  27. expect(requestOptions.url).to.be('/api/suggest');
  28. });
  29. it('tag_names(cpu) should generate looku query', function() {
  30. ctx.ds.metricFindQuery('tag_names(cpu)').then(function(data) { results = data; });
  31. ctx.$rootScope.$apply();
  32. expect(requestOptions.url).to.be('/api/search/lookup');
  33. expect(requestOptions.params.m).to.be('cpu');
  34. });
  35. it('tag_values(cpu, test) should generate looku query', function() {
  36. ctx.ds.metricFindQuery('tag_values(cpu, hostname)').then(function(data) { results = data; });
  37. ctx.$rootScope.$apply();
  38. expect(requestOptions.url).to.be('/api/search/lookup');
  39. expect(requestOptions.params.m).to.be('cpu{hostname=*}');
  40. });
  41. });
  42. });
  43. });