Commit 21b97aa4 authored by Dhiraj Bodicherla's avatar Dhiraj Bodicherla Committed by rpereira2

Update metrics dashboard variables map

This MR updates the format of custom variables
the UI sends to the backend in metrics dashboard
parent f84f2d8b
...@@ -218,13 +218,16 @@ export const fetchPrometheusMetric = ( ...@@ -218,13 +218,16 @@ export const fetchPrometheusMetric = (
{ commit, state, getters }, { commit, state, getters },
{ metric, defaultQueryParams }, { metric, defaultQueryParams },
) => { ) => {
const queryParams = { ...defaultQueryParams }; let queryParams = { ...defaultQueryParams };
if (metric.step) { if (metric.step) {
queryParams.step = metric.step; queryParams.step = metric.step;
} }
if (Object.keys(state.variables).length > 0) { if (Object.keys(state.variables).length > 0) {
queryParams.variables = getters.getCustomVariablesArray; queryParams = {
...queryParams,
...getters.getCustomVariablesParams,
};
} }
commit(types.REQUEST_METRIC_RESULT, { metricId: metric.metricId }); commit(types.REQUEST_METRIC_RESULT, { metricId: metric.metricId });
......
import { flatMap } from 'lodash';
import { NOT_IN_DB_PREFIX } from '../constants'; import { NOT_IN_DB_PREFIX } from '../constants';
import { addPrefixToCustomVariableParams } from './utils';
const metricsIdsInPanel = panel => const metricsIdsInPanel = panel =>
panel.metrics.filter(metric => metric.metricId && metric.result).map(metric => metric.metricId); panel.metrics.filter(metric => metric.metricId && metric.result).map(metric => metric.metricId);
...@@ -116,13 +116,27 @@ export const filteredEnvironments = state => ...@@ -116,13 +116,27 @@ export const filteredEnvironments = state =>
* Maps an variables object to an array along with stripping * Maps an variables object to an array along with stripping
* the variable prefix. * the variable prefix.
* *
* This method outputs an object in the below format
*
* {
* variables[key1]=value1,
* variables[key2]=value2,
* }
*
* This is done so that the backend can identify the custom
* user-defined variables coming through the URL and differentiate
* from other variables used for Prometheus API endpoint.
*
* @param {Object} variables - Custom variables provided by the user * @param {Object} variables - Custom variables provided by the user
* @returns {Array} The custom variables array to be send to the API * @returns {Array} The custom variables array to be send to the API
* in the format of [variable1, variable1_value] * in the format of {variables[key1]=value1, variables[key2]=value2}
*/ */
export const getCustomVariablesArray = state => export const getCustomVariablesParams = state =>
flatMap(state.variables, (variable, key) => [key, variable.value]); Object.keys(state.variables).reduce((acc, variable) => {
acc[addPrefixToCustomVariableParams(variable)] = state.variables[variable]?.value;
return acc;
}, {});
// prevent babel-plugin-rewire from generating an invalid default during karma tests // prevent babel-plugin-rewire from generating an invalid default during karma tests
export default () => {}; export default () => {};
...@@ -229,3 +229,19 @@ export const normalizeQueryResult = timeSeries => { ...@@ -229,3 +229,19 @@ export const normalizeQueryResult = timeSeries => {
return normalizedResult; return normalizedResult;
}; };
/**
* Custom variables defined in the dashboard yml file are
* eventually passed over the wire to the backend Prometheus
* API proxy.
*
* This method adds a prefix to the URL param keys so that
* the backend can differential these variables from the other
* variables.
*
* This is currently only used by getters/getCustomVariablesParams
*
* @param {String} key Variable key that needs to be prefixed
* @returns {String}
*/
export const addPrefixToCustomVariableParams = key => `variables[${key}]`;
---
title: Change format of variables parameter in Prometheus proxy API for metrics dashboard
merge_request: 33062
author:
type: fixed
...@@ -329,7 +329,7 @@ describe('Monitoring store Getters', () => { ...@@ -329,7 +329,7 @@ describe('Monitoring store Getters', () => {
}); });
}); });
describe('getCustomVariablesArray', () => { describe('getCustomVariablesParams', () => {
let state; let state;
beforeEach(() => { beforeEach(() => {
...@@ -340,25 +340,21 @@ describe('Monitoring store Getters', () => { ...@@ -340,25 +340,21 @@ describe('Monitoring store Getters', () => {
it('transforms the variables object to an array in the [variable, variable_value] format for all variable types', () => { it('transforms the variables object to an array in the [variable, variable_value] format for all variable types', () => {
mutations[types.SET_VARIABLES](state, mockTemplatingDataResponses.allVariableTypes); mutations[types.SET_VARIABLES](state, mockTemplatingDataResponses.allVariableTypes);
const variablesArray = getters.getCustomVariablesArray(state); const variablesArray = getters.getCustomVariablesParams(state);
expect(variablesArray).toEqual([ expect(variablesArray).toEqual({
'simpleText', 'variables[advCustomNormal]': 'value2',
'Simple text', 'variables[advText]': 'default',
'advText', 'variables[simpleCustom]': 'value1',
'default', 'variables[simpleText]': 'Simple text',
'simpleCustom', });
'value1',
'advCustomNormal',
'value2',
]);
}); });
it('transforms the variables object to an empty array when no keys are present', () => { it('transforms the variables object to an empty array when no keys are present', () => {
mutations[types.SET_VARIABLES](state, {}); mutations[types.SET_VARIABLES](state, {});
const variablesArray = getters.getCustomVariablesArray(state); const variablesArray = getters.getCustomVariablesParams(state);
expect(variablesArray).toEqual([]); expect(variablesArray).toEqual({});
}); });
}); });
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment