Plugins: InfluxDB variable interpolation fix for influxdbBackendMigration feature flag (#51624)

This commit is contained in:
ismail simsek
2022-07-06 19:27:21 +02:00
committed by GitHub
parent 9f6297ca9b
commit 9941e06e22
2 changed files with 47 additions and 20 deletions

View File

@@ -5,6 +5,7 @@ import { v4 as uuidv4 } from 'uuid';
import {
AnnotationEvent,
AnnotationQueryRequest,
ArrayVector,
DataFrame,
DataQueryError,
@@ -21,7 +22,6 @@ import {
TIME_SERIES_TIME_FIELD_NAME,
TIME_SERIES_VALUE_FIELD_NAME,
TimeSeries,
AnnotationQueryRequest,
} from '@grafana/data';
import {
BackendDataSourceResponse,
@@ -240,7 +240,7 @@ export default class InfluxDatasource extends DataSourceWithBackend<InfluxQuery,
if (this.isFlux) {
return {
...query,
query: this.templateSrv.replace(query.query ?? '', rest), // The raw query text
query: this.templateSrv.replace(query.query ?? '', rest, 'regex'), // The raw query text
};
}
@@ -368,7 +368,7 @@ export default class InfluxDatasource extends DataSourceWithBackend<InfluxQuery,
const target: InfluxQuery = {
refId: 'metricFindQuery',
datasource: this.getRef(),
query: this.templateSrv.replace(options.annotation.query ?? ''),
query: this.templateSrv.replace(options.annotation.query ?? '', undefined, 'regex'),
rawQuery: true,
};
@@ -426,7 +426,7 @@ export default class InfluxDatasource extends DataSourceWithBackend<InfluxQuery,
return {
...query,
datasource: this.getRef(),
query: this.templateSrv.replace(query.query ?? '', scopedVars), // The raw query text
query: this.templateSrv.replace(query.query ?? '', scopedVars, 'regex'), // The raw query text
};
}
@@ -475,7 +475,7 @@ export default class InfluxDatasource extends DataSourceWithBackend<InfluxQuery,
return {
...expandedQuery,
query: this.templateSrv.replace(query.query ?? '', rest), // The raw query text
query: this.templateSrv.replace(query.query ?? '', rest, 'regex'), // The raw query text
alias: this.templateSrv.replace(query.alias ?? '', scopedVars),
limit: this.templateSrv.replace(query.limit?.toString() ?? '', scopedVars, 'regex'),
measurement: this.templateSrv.replace(query.measurement ?? '', scopedVars, 'regex'),

View File

@@ -1,6 +1,7 @@
import { lastValueFrom, of } from 'rxjs';
import { TemplateSrvStub } from 'test/specs/helpers';
import { ScopedVars } from '@grafana/data/src';
import { FetchResponse } from '@grafana/runtime';
import config from 'app/core/config';
import { backendSrv } from 'app/core/services/backend_srv'; // will use the version in __mocks__
@@ -179,15 +180,31 @@ describe('InfluxDataSource', () => {
});
describe('Variables should be interpolated correctly', () => {
const templateSrv: any = { replace: jest.fn() };
const instanceSettings: any = {};
const ds = new InfluxDatasource(instanceSettings, templateSrv);
const text = 'interpolationText';
templateSrv.replace.mockReturnValue(text);
const text2 = 'interpolationText2';
const textWithoutFormatRegex = 'interpolationText,interpolationText2';
const textWithFormatRegex = 'interpolationText|interpolationText2';
const variableMap: Record<string, string> = {
$interpolationVar: text,
$interpolationVar2: text2,
};
const templateSrv: any = {
replace: jest.fn((target?: string, scopedVars?: ScopedVars, format?: string | Function): string => {
if (!format) {
return variableMap[target!] || '';
}
if (format === 'regex') {
return textWithFormatRegex;
}
return textWithoutFormatRegex;
}),
};
const ds = new InfluxDatasource(instanceSettings, templateSrv);
const fluxQuery = {
refId: 'x',
query: '$interpolationVar',
query: '$interpolationVar,$interpolationVar2',
};
const influxQuery = {
@@ -202,7 +219,7 @@ describe('InfluxDataSource', () => {
{
key: 'cpu',
operator: '=~',
value: '/^$interpolationVar$/',
value: '/^$interpolationVar,$interpolationVar2$/',
},
],
groupBy: [
@@ -223,20 +240,20 @@ describe('InfluxDataSource', () => {
function fluxChecks(query: any) {
expect(templateSrv.replace).toBeCalledTimes(1);
expect(query).toBe(text);
expect(query).toBe(textWithFormatRegex);
}
function influxChecks(query: any) {
expect(templateSrv.replace).toBeCalledTimes(10);
expect(query.alias).toBe(text);
expect(query.measurement).toBe(text);
expect(query.policy).toBe(text);
expect(query.limit).toBe(text);
expect(query.slimit).toBe(text);
expect(query.measurement).toBe(textWithFormatRegex);
expect(query.policy).toBe(textWithFormatRegex);
expect(query.limit).toBe(textWithFormatRegex);
expect(query.slimit).toBe(textWithFormatRegex);
expect(query.tz).toBe(text);
expect(query.tags![0].value).toBe(text);
expect(query.groupBy![0].params![0]).toBe(text);
expect(query.select![0][0].params![0]).toBe(text);
expect(query.tags![0].value).toBe(textWithFormatRegex);
expect(query.groupBy![0].params![0]).toBe(textWithFormatRegex);
expect(query.select![0][0].params![0]).toBe(textWithFormatRegex);
}
describe('when interpolating query variables for dashboard->explore', () => {
@@ -244,6 +261,7 @@ describe('InfluxDataSource', () => {
ds.isFlux = true;
const queries = ds.interpolateVariablesInQueries([fluxQuery], {
interpolationVar: { text: text, value: text },
interpolationVar2: { text: text2, value: text2 },
});
fluxChecks(queries[0].query);
});
@@ -252,6 +270,7 @@ describe('InfluxDataSource', () => {
ds.isFlux = false;
const queries = ds.interpolateVariablesInQueries([influxQuery], {
interpolationVar: { text: text, value: text },
interpolationVar2: { text: text2, value: text2 },
});
influxChecks(queries[0]);
});
@@ -260,7 +279,12 @@ describe('InfluxDataSource', () => {
describe('when interpolating template variables', () => {
it('should apply all template variables with Flux mode', () => {
ds.isFlux = true;
const query = ds.applyTemplateVariables(fluxQuery, { interpolationVar: { text: text, value: text } });
const query = ds.applyTemplateVariables(fluxQuery, {
interpolationVar: {
text: text,
value: text,
},
});
fluxChecks(query.query);
});
@@ -268,7 +292,10 @@ describe('InfluxDataSource', () => {
ds.isFlux = false;
ds.access = 'proxy';
config.featureToggles.influxdbBackendMigration = true;
const query = ds.applyTemplateVariables(influxQuery, { interpolationVar: { text: text, value: text } });
const query = ds.applyTemplateVariables(influxQuery, {
interpolationVar: { text: text, value: text },
interpolationVar2: { text: 'interpolationText2', value: 'interpolationText2' },
});
influxChecks(query);
});
});