Commit 5acc9d4f authored by Tristan Read's avatar Tristan Read Committed by Jose Ivan Vargas

Move metrics dashboard alerts behind feature flag

parent 30078887
...@@ -26,6 +26,7 @@ import { ...@@ -26,6 +26,7 @@ import {
} from '~/vue_shared/components/paginated_table_with_search_and_tabs/constants'; } from '~/vue_shared/components/paginated_table_with_search_and_tabs/constants';
import PaginatedTableWithSearchAndTabs from '~/vue_shared/components/paginated_table_with_search_and_tabs/paginated_table_with_search_and_tabs.vue'; import PaginatedTableWithSearchAndTabs from '~/vue_shared/components/paginated_table_with_search_and_tabs/paginated_table_with_search_and_tabs.vue';
import TimeAgo from '~/vue_shared/components/time_ago_tooltip.vue'; import TimeAgo from '~/vue_shared/components/time_ago_tooltip.vue';
import glFeatureFlagMixin from '~/vue_shared/mixins/gl_feature_flags_mixin';
import { ALERTS_STATUS_TABS, SEVERITY_LEVELS, trackAlertListViewsOptions } from '../constants'; import { ALERTS_STATUS_TABS, SEVERITY_LEVELS, trackAlertListViewsOptions } from '../constants';
import getAlertsCountByStatus from '../graphql/queries/get_count_by_status.query.graphql'; import getAlertsCountByStatus from '../graphql/queries/get_count_by_status.query.graphql';
...@@ -114,6 +115,7 @@ export default { ...@@ -114,6 +115,7 @@ export default {
directives: { directives: {
GlTooltip: GlTooltipDirective, GlTooltip: GlTooltipDirective,
}, },
mixins: [glFeatureFlagMixin()],
inject: ['projectPath', 'textQuery', 'assigneeUsernameQuery', 'populatingAlertsHelpUrl'], inject: ['projectPath', 'textQuery', 'assigneeUsernameQuery', 'populatingAlertsHelpUrl'],
apollo: { apollo: {
alerts: { alerts: {
...@@ -275,7 +277,7 @@ export default { ...@@ -275,7 +277,7 @@ export default {
</gl-sprintf> </gl-sprintf>
</gl-alert> </gl-alert>
<alerts-deprecation-warning /> <alerts-deprecation-warning v-if="!glFeatures.managedAlertsDeprecation" />
<paginated-table-with-search-and-tabs <paginated-table-with-search-and-tabs
:show-error-msg="showErrorMsg" :show-error-msg="showErrorMsg"
......
...@@ -11,6 +11,7 @@ import { s__ } from '~/locale'; ...@@ -11,6 +11,7 @@ import { s__ } from '~/locale';
import AlertsDeprecationWarning from '~/vue_shared/components/alerts_deprecation_warning.vue'; import AlertsDeprecationWarning from '~/vue_shared/components/alerts_deprecation_warning.vue';
import { defaultTimeRange } from '~/vue_shared/constants'; import { defaultTimeRange } from '~/vue_shared/constants';
import TrackEventDirective from '~/vue_shared/directives/track_event'; import TrackEventDirective from '~/vue_shared/directives/track_event';
import glFeatureFlagMixin from '~/vue_shared/mixins/gl_feature_flags_mixin';
import { metricStates, keyboardShortcutKeys } from '../constants'; import { metricStates, keyboardShortcutKeys } from '../constants';
import { import {
timeRangeFromUrl, timeRangeFromUrl,
...@@ -46,6 +47,7 @@ export default { ...@@ -46,6 +47,7 @@ export default {
GlTooltip: GlTooltipDirective, GlTooltip: GlTooltipDirective,
TrackEvent: TrackEventDirective, TrackEvent: TrackEventDirective,
}, },
mixins: [glFeatureFlagMixin()],
props: { props: {
hasMetrics: { hasMetrics: {
type: Boolean, type: Boolean,
...@@ -397,7 +399,7 @@ export default { ...@@ -397,7 +399,7 @@ export default {
<template> <template>
<div class="prometheus-graphs" data-qa-selector="prometheus_graphs"> <div class="prometheus-graphs" data-qa-selector="prometheus_graphs">
<alerts-deprecation-warning /> <alerts-deprecation-warning v-if="!glFeatures.managedAlertsDeprecation" />
<dashboard-header <dashboard-header
v-if="showHeader" v-if="showHeader"
......
...@@ -21,6 +21,7 @@ import invalidUrl from '~/lib/utils/invalid_url'; ...@@ -21,6 +21,7 @@ import invalidUrl from '~/lib/utils/invalid_url';
import { relativePathToAbsolute, getBaseURL, visitUrl, isSafeURL } from '~/lib/utils/url_utility'; import { relativePathToAbsolute, getBaseURL, visitUrl, isSafeURL } from '~/lib/utils/url_utility';
import { __, n__ } from '~/locale'; import { __, n__ } from '~/locale';
import TrackEventDirective from '~/vue_shared/directives/track_event'; import TrackEventDirective from '~/vue_shared/directives/track_event';
import glFeatureFlagMixin from '~/vue_shared/mixins/gl_feature_flags_mixin';
import { panelTypes } from '../constants'; import { panelTypes } from '../constants';
import { graphDataToCsv } from '../csv_export'; import { graphDataToCsv } from '../csv_export';
...@@ -61,6 +62,7 @@ export default { ...@@ -61,6 +62,7 @@ export default {
GlTooltip: GlTooltipDirective, GlTooltip: GlTooltipDirective,
TrackEvent: TrackEventDirective, TrackEvent: TrackEventDirective,
}, },
mixins: [glFeatureFlagMixin()],
props: { props: {
clipboardText: { clipboardText: {
type: String, type: String,
...@@ -258,7 +260,8 @@ export default { ...@@ -258,7 +260,8 @@ export default {
this.prometheusAlertsAvailable && this.prometheusAlertsAvailable &&
this.alertsEndpoint && this.alertsEndpoint &&
this.graphData && this.graphData &&
this.hasMetricsInDb this.hasMetricsInDb &&
!this.glFeatures.managedAlertsDeprecation
); );
}, },
alertModalId() { alertModalId() {
......
...@@ -22,7 +22,12 @@ export default { ...@@ -22,7 +22,12 @@ export default {
</script> </script>
<template> <template>
<gl-alert v-if="hasManagedPrometheus" variant="warning" class="my-2"> <gl-alert
v-if="hasManagedPrometheus"
variant="warning"
class="my-2"
data-testid="alerts-deprecation-warning"
>
<gl-sprintf :message="$options.i18n.alertsDeprecationText"> <gl-sprintf :message="$options.i18n.alertsDeprecationText">
<template #link="{ content }"> <template #link="{ content }">
<gl-link <gl-link
......
...@@ -12,6 +12,7 @@ module Projects ...@@ -12,6 +12,7 @@ module Projects
before_action do before_action do
push_frontend_feature_flag(:prometheus_computed_alerts) push_frontend_feature_flag(:prometheus_computed_alerts)
push_frontend_feature_flag(:disable_metric_dashboard_refresh_rate) push_frontend_feature_flag(:disable_metric_dashboard_refresh_rate)
push_frontend_feature_flag(:managed_alerts_deprecation, @project)
end end
feature_category :metrics feature_category :metrics
......
...@@ -7,7 +7,6 @@ import { extendedWrapper } from 'helpers/vue_test_utils_helper'; ...@@ -7,7 +7,6 @@ import { extendedWrapper } from 'helpers/vue_test_utils_helper';
import mockAlerts from 'jest/vue_shared/alert_details/mocks/alerts.json'; import mockAlerts from 'jest/vue_shared/alert_details/mocks/alerts.json';
import AlertManagementTable from '~/alert_management/components/alert_management_table.vue'; import AlertManagementTable from '~/alert_management/components/alert_management_table.vue';
import { visitUrl } from '~/lib/utils/url_utility'; import { visitUrl } from '~/lib/utils/url_utility';
import AlertDeprecationWarning from '~/vue_shared/components/alerts_deprecation_warning.vue';
import FilteredSearchBar from '~/vue_shared/components/filtered_search_bar/filtered_search_bar_root.vue'; import FilteredSearchBar from '~/vue_shared/components/filtered_search_bar/filtered_search_bar_root.vue';
import TimeAgo from '~/vue_shared/components/time_ago_tooltip.vue'; import TimeAgo from '~/vue_shared/components/time_ago_tooltip.vue';
import defaultProvideValues from '../mocks/alerts_provide_config.json'; import defaultProvideValues from '../mocks/alerts_provide_config.json';
...@@ -41,8 +40,7 @@ describe('AlertManagementTable', () => { ...@@ -41,8 +40,7 @@ describe('AlertManagementTable', () => {
resolved: 11, resolved: 11,
all: 26, all: 26,
}; };
const findDeprecationNotice = () => const findDeprecationNotice = () => wrapper.findByTestId('alerts-deprecation-warning');
wrapper.findComponent(AlertDeprecationWarning).findComponent(GlAlert);
function mountComponent({ provide = {}, data = {}, loading = false, stubs = {} } = {}) { function mountComponent({ provide = {}, data = {}, loading = false, stubs = {} } = {}) {
wrapper = extendedWrapper( wrapper = extendedWrapper(
...@@ -239,19 +237,21 @@ describe('AlertManagementTable', () => { ...@@ -239,19 +237,21 @@ describe('AlertManagementTable', () => {
expect(visitUrl).toHaveBeenCalledWith('/1527542/details', true); expect(visitUrl).toHaveBeenCalledWith('/1527542/details', true);
}); });
describe('deprecation notice', () => { it.each`
it('shows the deprecation notice when available', () => { managedAlertsDeprecation | hasManagedPrometheus | isVisible
mountComponent({ provide: { hasManagedPrometheus: true } }); ${false} | ${false} | ${false}
${false} | ${true} | ${true}
expect(findDeprecationNotice().exists()).toBe(true); ${true} | ${false} | ${false}
}); ${true} | ${true} | ${false}
`(
it('hides the deprecation notice when not available', () => { 'when the deprecation feature flag is $managedAlertsDeprecation and has managed prometheus is $hasManagedPrometheus',
mountComponent(); ({ hasManagedPrometheus, managedAlertsDeprecation, isVisible }) => {
mountComponent({
expect(findDeprecationNotice().exists()).toBe(false); provide: { hasManagedPrometheus, glFeatures: { managedAlertsDeprecation } },
});
}); });
expect(findDeprecationNotice().exists()).toBe(isVisible);
},
);
describe('alert issue links', () => { describe('alert issue links', () => {
beforeEach(() => { beforeEach(() => {
......
...@@ -778,5 +778,31 @@ describe('Dashboard Panel', () => { ...@@ -778,5 +778,31 @@ describe('Dashboard Panel', () => {
expect(findRunbookLinks().at(0).attributes('href')).toBe(invalidUrl); expect(findRunbookLinks().at(0).attributes('href')).toBe(invalidUrl);
}); });
}); });
describe('managed alert deprecation feature flag', () => {
beforeEach(() => {
setMetricsSavedToDb([metricId]);
});
it('shows alerts when alerts are not deprecated', () => {
createWrapper(
{ alertsEndpoint: '/endpoint', prometheusAlertsAvailable: true },
{ provide: { glFeatures: { managedAlertsDeprecation: false } } },
);
expect(findAlertsWidget().exists()).toBe(true);
expect(findMenuItemByText('Alerts').exists()).toBe(true);
});
it('hides alerts when alerts are deprecated', () => {
createWrapper(
{ alertsEndpoint: '/endpoint', prometheusAlertsAvailable: true },
{ provide: { glFeatures: { managedAlertsDeprecation: true } } },
);
expect(findAlertsWidget().exists()).toBe(false);
expect(findMenuItemByText('Alerts').exists()).toBe(false);
});
});
}); });
}); });
import { GlAlert } from '@gitlab/ui';
import { shallowMount, mount } from '@vue/test-utils';
import MockAdapter from 'axios-mock-adapter'; import MockAdapter from 'axios-mock-adapter';
import VueDraggable from 'vuedraggable'; import VueDraggable from 'vuedraggable';
import { TEST_HOST } from 'helpers/test_constants'; import { TEST_HOST } from 'helpers/test_constants';
import { mountExtended, shallowMountExtended } from 'helpers/vue_test_utils_helper';
import createFlash from '~/flash'; import createFlash from '~/flash';
import axios from '~/lib/utils/axios_utils'; import axios from '~/lib/utils/axios_utils';
import { ESC_KEY } from '~/lib/utils/keys'; import { ESC_KEY } from '~/lib/utils/keys';
...@@ -17,7 +16,6 @@ import LinksSection from '~/monitoring/components/links_section.vue'; ...@@ -17,7 +16,6 @@ import LinksSection from '~/monitoring/components/links_section.vue';
import { dashboardEmptyStates, metricStates } from '~/monitoring/constants'; import { dashboardEmptyStates, metricStates } from '~/monitoring/constants';
import { createStore } from '~/monitoring/stores'; import { createStore } from '~/monitoring/stores';
import * as types from '~/monitoring/stores/mutation_types'; import * as types from '~/monitoring/stores/mutation_types';
import AlertDeprecationWarning from '~/vue_shared/components/alerts_deprecation_warning.vue';
import { import {
metricsDashboardViewModel, metricsDashboardViewModel,
metricsDashboardPanelCount, metricsDashboardPanelCount,
...@@ -41,7 +39,7 @@ describe('Dashboard', () => { ...@@ -41,7 +39,7 @@ describe('Dashboard', () => {
let mock; let mock;
const createShallowWrapper = (props = {}, options = {}) => { const createShallowWrapper = (props = {}, options = {}) => {
wrapper = shallowMount(Dashboard, { wrapper = shallowMountExtended(Dashboard, {
propsData: { ...dashboardProps, ...props }, propsData: { ...dashboardProps, ...props },
store, store,
stubs: { stubs: {
...@@ -53,7 +51,7 @@ describe('Dashboard', () => { ...@@ -53,7 +51,7 @@ describe('Dashboard', () => {
}; };
const createMountedWrapper = (props = {}, options = {}) => { const createMountedWrapper = (props = {}, options = {}) => {
wrapper = mount(Dashboard, { wrapper = mountExtended(Dashboard, {
propsData: { ...dashboardProps, ...props }, propsData: { ...dashboardProps, ...props },
store, store,
stubs: { stubs: {
...@@ -818,24 +816,28 @@ describe('Dashboard', () => { ...@@ -818,24 +816,28 @@ describe('Dashboard', () => {
}); });
}); });
describe('deprecation notice', () => { describe('alerts deprecation', () => {
beforeEach(() => { beforeEach(() => {
setupStoreWithData(store); setupStoreWithData(store);
}); });
const findDeprecationNotice = () => const findDeprecationNotice = () => wrapper.findByTestId('alerts-deprecation-warning');
wrapper.find(AlertDeprecationWarning).findComponent(GlAlert);
it.each`
it('shows the deprecation notice when available', () => { managedAlertsDeprecation | hasManagedPrometheus | isVisible
createMountedWrapper({}, { provide: { hasManagedPrometheus: true } }); ${false} | ${false} | ${false}
${false} | ${true} | ${true}
expect(findDeprecationNotice().exists()).toBe(true); ${true} | ${false} | ${false}
}); ${true} | ${true} | ${false}
`(
it('hides the deprecation notice when not available', () => { 'when the deprecation feature flag is $managedAlertsDeprecation and has managed prometheus is $hasManagedPrometheus',
createMountedWrapper(); ({ hasManagedPrometheus, managedAlertsDeprecation, isVisible }) => {
createMountedWrapper(
expect(findDeprecationNotice().exists()).toBe(false); {},
}); { provide: { hasManagedPrometheus, glFeatures: { managedAlertsDeprecation } } },
);
expect(findDeprecationNotice().exists()).toBe(isVisible);
},
);
}); });
}); });
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