| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197 |
- import {describe, beforeEach, it, sinon, expect, angularMocks} from 'test/lib/common';
- import moment from 'moment';
- import helpers from 'test/specs/helpers';
- import {MysqlDatasource} from '../datasource';
- describe('MySQLDatasource', function() {
- var ctx = new helpers.ServiceTestContext();
- var instanceSettings = {name: 'mysql'};
- beforeEach(angularMocks.module('grafana.core'));
- beforeEach(angularMocks.module('grafana.services'));
- beforeEach(ctx.providePhase(['backendSrv']));
- beforeEach(angularMocks.inject(function($q, $rootScope, $httpBackend, $injector) {
- ctx.$q = $q;
- ctx.$httpBackend = $httpBackend;
- ctx.$rootScope = $rootScope;
- ctx.ds = $injector.instantiate(MysqlDatasource, {instanceSettings: instanceSettings});
- $httpBackend.when('GET', /\.html$/).respond('');
- }));
- describe('When performing annotationQuery', function() {
- let results;
- const annotationName = 'MyAnno';
- const options = {
- annotation: {
- name: annotationName,
- rawQuery: 'select time_sec, title, text, tags from table;'
- },
- range: {
- from: moment(1432288354),
- to: moment(1432288401)
- }
- };
- const response = {
- results: {
- MyAnno: {
- refId: annotationName,
- tables: [
- {
- columns: [{text: 'time_sec'}, {text: 'title'}, {text: 'text'}, {text: 'tags'}],
- rows: [
- [1432288355, 'aTitle', 'some text', 'TagA,TagB'],
- [1432288390, 'aTitle2', 'some text2', ' TagB , TagC'],
- [1432288400, 'aTitle3', 'some text3']
- ]
- }
- ]
- }
- }
- };
- beforeEach(function() {
- ctx.backendSrv.datasourceRequest = function(options) {
- return ctx.$q.when({data: response, status: 200});
- };
- ctx.ds.annotationQuery(options).then(function(data) { results = data; });
- ctx.$rootScope.$apply();
- });
- it('should return annotation list', function() {
- expect(results.length).to.be(3);
- expect(results[0].title).to.be('aTitle');
- expect(results[0].text).to.be('some text');
- expect(results[0].tags[0]).to.be('TagA');
- expect(results[0].tags[1]).to.be('TagB');
- expect(results[1].tags[0]).to.be('TagB');
- expect(results[1].tags[1]).to.be('TagC');
- expect(results[2].tags.length).to.be(0);
- });
- });
- describe('When performing metricFindQuery', function() {
- let results;
- const query = 'select * from atable';
- const response = {
- results: {
- tempvar: {
- meta: {
- rowCount: 3
- },
- refId: 'tempvar',
- tables: [
- {
- columns: [{text: 'title'}, {text: 'text'}],
- rows: [
- ['aTitle', 'some text'],
- ['aTitle2', 'some text2'],
- ['aTitle3', 'some text3']
- ]
- }
- ]
- }
- }
- };
- beforeEach(function() {
- ctx.backendSrv.datasourceRequest = function(options) {
- return ctx.$q.when({data: response, status: 200});
- };
- ctx.ds.metricFindQuery(query).then(function(data) { results = data; });
- ctx.$rootScope.$apply();
- });
- it('should return list of all column values', function() {
- expect(results.length).to.be(6);
- expect(results[0].text).to.be('aTitle');
- expect(results[5].text).to.be('some text3');
- });
- });
- describe('When performing metricFindQuery with key, value columns', function() {
- let results;
- const query = 'select * from atable';
- const response = {
- results: {
- tempvar: {
- meta: {
- rowCount: 3
- },
- refId: 'tempvar',
- tables: [
- {
- columns: [{text: '__value'}, {text: '__text'}],
- rows: [
- ['value1', 'aTitle'],
- ['value2', 'aTitle2'],
- ['value3', 'aTitle3']
- ]
- }
- ]
- }
- }
- };
- beforeEach(function() {
- ctx.backendSrv.datasourceRequest = function(options) {
- return ctx.$q.when({data: response, status: 200});
- };
- ctx.ds.metricFindQuery(query).then(function(data) { results = data; });
- ctx.$rootScope.$apply();
- });
- it('should return list of as text, value', function() {
- expect(results.length).to.be(3);
- expect(results[0].text).to.be('aTitle');
- expect(results[0].value).to.be('value1');
- expect(results[2].text).to.be('aTitle3');
- expect(results[2].value).to.be('value3');
- });
- });
- describe('When performing metricFindQuery with key, value columns and with duplicate keys', function() {
- let results;
- const query = 'select * from atable';
- const response = {
- results: {
- tempvar: {
- meta: {
- rowCount: 3
- },
- refId: 'tempvar',
- tables: [
- {
- columns: [{text: '__text'}, {text: '__value'}],
- rows: [
- ['aTitle', 'same'],
- ['aTitle', 'same'],
- ['aTitle', 'diff']
- ]
- }
- ]
- }
- }
- };
- beforeEach(function() {
- ctx.backendSrv.datasourceRequest = function(options) {
- return ctx.$q.when({data: response, status: 200});
- };
- ctx.ds.metricFindQuery(query).then(function(data) { results = data; });
- ctx.$rootScope.$apply();
- });
- it('should return list of unique keys', function() {
- expect(results.length).to.be(1);
- expect(results[0].text).to.be('aTitle');
- expect(results[0].value).to.be('same');
- });
- });
- });
|