Commit 847ccebd authored by Andrei Stoicescu's avatar Andrei Stoicescu Committed by Mark Florian

Filter out inactive environments in monitoring dropdown

  - add 'states' filter to environments graphQL query
  - use 'available' value to filter environments
parent 80987803
...@@ -109,3 +109,9 @@ export const initialStateKeys = [...endpointKeys, 'currentEnvironmentName']; ...@@ -109,3 +109,9 @@ export const initialStateKeys = [...endpointKeys, 'currentEnvironmentName'];
* Constant to indicate if a metric exists in the database * Constant to indicate if a metric exists in the database
*/ */
export const NOT_IN_DB_PREFIX = 'NO_DB'; export const NOT_IN_DB_PREFIX = 'NO_DB';
/**
* graphQL environments API value for active environments.
* Used as a value for the 'states' query filter
*/
export const ENVIRONMENT_AVAILABLE_STATE = 'available';
query getEnvironments($projectPath: ID!, $search: String) { query getEnvironments($projectPath: ID!, $search: String, $states: [String!]) {
project(fullPath: $projectPath) { project(fullPath: $projectPath) {
data: environments(search: $search) { data: environments(search: $search, states: $states) {
environments: nodes { environments: nodes {
name name
id id
......
...@@ -10,7 +10,7 @@ import statusCodes from '../../lib/utils/http_status'; ...@@ -10,7 +10,7 @@ import statusCodes from '../../lib/utils/http_status';
import { backOff, convertObjectPropsToCamelCase } from '../../lib/utils/common_utils'; import { backOff, convertObjectPropsToCamelCase } from '../../lib/utils/common_utils';
import { s__, sprintf } from '../../locale'; import { s__, sprintf } from '../../locale';
import { PROMETHEUS_TIMEOUT } from '../constants'; import { PROMETHEUS_TIMEOUT, ENVIRONMENT_AVAILABLE_STATE } from '../constants';
function prometheusMetricQueryParams(timeRange) { function prometheusMetricQueryParams(timeRange) {
const { start, end } = convertToFixedRange(timeRange); const { start, end } = convertToFixedRange(timeRange);
...@@ -238,6 +238,7 @@ export const fetchEnvironmentsData = ({ state, dispatch }) => { ...@@ -238,6 +238,7 @@ export const fetchEnvironmentsData = ({ state, dispatch }) => {
variables: { variables: {
projectPath: removeLeadingSlash(state.projectPath), projectPath: removeLeadingSlash(state.projectPath),
search: state.environmentsSearchTerm, search: state.environmentsSearchTerm,
states: [ENVIRONMENT_AVAILABLE_STATE],
}, },
}) })
.then(resp => .then(resp =>
......
---
title: Show only active environments in monitoring dropdown
merge_request: 28456
author:
type: changed
...@@ -6,6 +6,7 @@ import statusCodes from '~/lib/utils/http_status'; ...@@ -6,6 +6,7 @@ import statusCodes from '~/lib/utils/http_status';
import * as commonUtils from '~/lib/utils/common_utils'; import * as commonUtils from '~/lib/utils/common_utils';
import createFlash from '~/flash'; import createFlash from '~/flash';
import { defaultTimeRange } from '~/vue_shared/constants'; import { defaultTimeRange } from '~/vue_shared/constants';
import { ENVIRONMENT_AVAILABLE_STATE } from '~/monitoring/constants';
import store from '~/monitoring/stores'; import store from '~/monitoring/stores';
import * as types from '~/monitoring/stores/mutation_types'; import * as types from '~/monitoring/stores/mutation_types';
...@@ -157,17 +158,21 @@ describe('Monitoring store actions', () => { ...@@ -157,17 +158,21 @@ describe('Monitoring store actions', () => {
variables: { variables: {
projectPath: state.projectPath, projectPath: state.projectPath,
search: searchTerm, search: searchTerm,
states: [ENVIRONMENT_AVAILABLE_STATE],
}, },
}; };
state.environmentsSearchTerm = searchTerm; state.environmentsSearchTerm = searchTerm;
mockMutate.mockReturnValue(Promise.resolve()); mockMutate.mockResolvedValue({});
return testAction( return testAction(
fetchEnvironmentsData, fetchEnvironmentsData,
null, null,
state, state,
[], [],
[{ type: 'requestEnvironmentsData' }, { type: 'receiveEnvironmentsDataFailure' }], [
{ type: 'requestEnvironmentsData' },
{ type: 'receiveEnvironmentsDataSuccess', payload: [] },
],
() => { () => {
expect(mockMutate).toHaveBeenCalledWith(mutationVariables); expect(mockMutate).toHaveBeenCalledWith(mutationVariables);
}, },
......
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