mirror of
https://github.com/grafana/grafana.git
synced 2025-09-21 15:13:06 +08:00

* Explore: Transform prometheus query to elasticsearch query Enable a way to transform prometheus/loki labels to elasticsearch query. This make a link between metrics to logs. Examples: A prometheus query : rate(my_metric{label1="value1",label2!="value2",label3=~"value.+",label4!~".*tothemoon"}[5m]) Will be this elasticsearch query when switching to elasticsearch datasource: __name__:"my_metric" AND label1:"value1" AND NOT label2:"value2" AND label3:/value.+/ AND NOT label4:/.*tothemoon/ * fix test * remove non needed async * Use prism token instead of regex * fix test ./scripts/ci-frontend-metrics.sh * mock timesrv and TemplateSrv in test * Remove unnecessary await/async Co-authored-by: Melchior MOULIN <m.moulin@criteo.com> Co-authored-by: Andrej Ocenas <mr.ocenas@gmail.com>
120 lines
5.4 KiB
TypeScript
120 lines
5.4 KiB
TypeScript
import LanguageProvider from './language_provider';
|
|
import { PromQuery } from '../prometheus/types';
|
|
import { ElasticDatasource } from './datasource';
|
|
import { DataSourceInstanceSettings, dateTime } from '@grafana/data';
|
|
import { ElasticsearchOptions } from './types';
|
|
import { TemplateSrv } from '../../../features/templating/template_srv';
|
|
import { getTimeSrv, TimeSrv } from '../../../features/dashboard/services/TimeSrv';
|
|
import { getTemplateSrv } from '@grafana/runtime';
|
|
|
|
jest.mock('app/features/templating/template_srv', () => {
|
|
return {
|
|
getAdhocFilters: jest.fn(() => [] as any[]),
|
|
replace: jest.fn((a: string) => a),
|
|
};
|
|
});
|
|
|
|
jest.mock('app/features/dashboard/services/TimeSrv', () => ({
|
|
__esModule: true,
|
|
getTimeSrv: jest.fn().mockReturnValue({
|
|
timeRange(): any {
|
|
return {
|
|
from: dateTime(1531468681),
|
|
to: dateTime(1531489712),
|
|
};
|
|
},
|
|
}),
|
|
}));
|
|
|
|
const dataSource = new ElasticDatasource(
|
|
{
|
|
url: 'http://es.com',
|
|
database: '[asd-]YYYY.MM.DD',
|
|
jsonData: {
|
|
interval: 'Daily',
|
|
esVersion: 2,
|
|
timeField: '@time',
|
|
},
|
|
} as DataSourceInstanceSettings<ElasticsearchOptions>,
|
|
getTemplateSrv() as TemplateSrv,
|
|
getTimeSrv() as TimeSrv
|
|
);
|
|
describe('transform prometheus query to elasticsearch query', () => {
|
|
it('Prometheus query with exact equals labels ( 2 labels ) and metric __name__', () => {
|
|
const instance = new LanguageProvider(dataSource);
|
|
var promQuery: PromQuery = { refId: 'bar', expr: 'my_metric{label1="value1",label2="value2"}' };
|
|
const result = instance.importQueries([promQuery], 'prometheus');
|
|
expect(result).toEqual([
|
|
{ isLogsQuery: true, query: '__name__:"my_metric" AND label1:"value1" AND label2:"value2"', refId: 'bar' },
|
|
]);
|
|
});
|
|
it('Prometheus query with exact equals labels ( 1 labels ) and metric __name__', () => {
|
|
const instance = new LanguageProvider(dataSource);
|
|
var promQuery: PromQuery = { refId: 'bar', expr: 'my_metric{label1="value1"}' };
|
|
const result = instance.importQueries([promQuery], 'prometheus');
|
|
expect(result).toEqual([{ isLogsQuery: true, query: '__name__:"my_metric" AND label1:"value1"', refId: 'bar' }]);
|
|
});
|
|
it('Prometheus query with exact equals labels ( 1 labels )', () => {
|
|
const instance = new LanguageProvider(dataSource);
|
|
var promQuery: PromQuery = { refId: 'bar', expr: '{label1="value1"}' };
|
|
const result = instance.importQueries([promQuery], 'prometheus');
|
|
expect(result).toEqual([{ isLogsQuery: true, query: 'label1:"value1"', refId: 'bar' }]);
|
|
});
|
|
it('Prometheus query with no label and metric __name__', () => {
|
|
const instance = new LanguageProvider(dataSource);
|
|
var promQuery: PromQuery = { refId: 'bar', expr: 'my_metric{}' };
|
|
const result = instance.importQueries([promQuery], 'prometheus');
|
|
expect(result).toEqual([{ isLogsQuery: true, query: '__name__:"my_metric"', refId: 'bar' }]);
|
|
});
|
|
it('Prometheus query with no label and metric __name__ without bracket', () => {
|
|
const instance = new LanguageProvider(dataSource);
|
|
var promQuery: PromQuery = { refId: 'bar', expr: 'my_metric' };
|
|
const result = instance.importQueries([promQuery], 'prometheus');
|
|
expect(result).toEqual([{ isLogsQuery: true, query: '__name__:"my_metric"', refId: 'bar' }]);
|
|
});
|
|
it('Prometheus query with rate function and exact equals labels ( 2 labels ) and metric __name__', () => {
|
|
const instance = new LanguageProvider(dataSource);
|
|
var promQuery: PromQuery = { refId: 'bar', expr: 'rate(my_metric{label1="value1",label2="value2"}[5m])' };
|
|
const result = instance.importQueries([promQuery], 'prometheus');
|
|
expect(result).toEqual([
|
|
{ isLogsQuery: true, query: '__name__:"my_metric" AND label1:"value1" AND label2:"value2"', refId: 'bar' },
|
|
]);
|
|
});
|
|
it('Prometheus query with rate function and exact equals labels not equals labels regex and not regex labels and metric __name__', () => {
|
|
const instance = new LanguageProvider(dataSource);
|
|
var promQuery: PromQuery = {
|
|
refId: 'bar',
|
|
expr: 'rate(my_metric{label1="value1",label2!="value2",label3=~"value.+",label4!~".*tothemoon"}[5m])',
|
|
};
|
|
const result = instance.importQueries([promQuery], 'prometheus');
|
|
expect(result).toEqual([
|
|
{
|
|
isLogsQuery: true,
|
|
query:
|
|
'__name__:"my_metric" AND label1:"value1" AND NOT label2:"value2" AND label3:/value.+/ AND NOT label4:/.*tothemoon/',
|
|
refId: 'bar',
|
|
},
|
|
]);
|
|
});
|
|
});
|
|
describe('transform prometheus query to elasticsearch query errors', () => {
|
|
it('bad prometheus query with only bracket', () => {
|
|
const instance = new LanguageProvider(dataSource);
|
|
var promQuery: PromQuery = { refId: 'bar', expr: '{' };
|
|
const result = instance.importQueries([promQuery], 'prometheus');
|
|
expect(result).toEqual([{ isLogsQuery: true, query: '', refId: 'bar' }]);
|
|
});
|
|
it('bad prometheus empty query', async () => {
|
|
const instance = new LanguageProvider(dataSource);
|
|
var promQuery: PromQuery = { refId: 'bar', expr: '' };
|
|
const result = instance.importQueries([promQuery], 'prometheus');
|
|
expect(result).toEqual([{ isLogsQuery: true, query: '', refId: 'bar' }]);
|
|
});
|
|
it('graphite query not handle', async () => {
|
|
const instance = new LanguageProvider(dataSource);
|
|
var promQuery: PromQuery = { refId: 'bar', expr: '' };
|
|
const result = instance.importQueries([promQuery], 'graphite');
|
|
expect(result).toEqual([{ isLogsQuery: true, query: '', refId: 'bar' }]);
|
|
});
|
|
});
|