Commit 19de7708 authored by Miguel Rincon's avatar Miguel Rincon

Refactor specs to improve mocking of getters

Instead of creating a new store to test panel type
this change uses the real namespaced module and mock the getter in it.
parent a13c4dfc
...@@ -209,7 +209,6 @@ export default { ...@@ -209,7 +209,6 @@ export default {
data-qa-selector="prometheus_graph_widgets" data-qa-selector="prometheus_graph_widgets"
> >
<div class="d-flex align-items-center"> <div class="d-flex align-items-center">
<!-- -->
<alert-widget <alert-widget
v-if="alertWidgetAvailable" v-if="alertWidgetAvailable"
:modal-id="`alert-modal-${index}`" :modal-id="`alert-modal-${index}`"
......
import Vuex from 'vuex'; import Vuex from 'vuex';
import { shallowMount, createLocalVue } from '@vue/test-utils'; import { shallowMount, createLocalVue } from '@vue/test-utils';
import { GlDropdownItem } from '@gitlab/ui'; import { GlDropdownItem } from '@gitlab/ui';
import { monitoringDashboard } from '~/monitoring/stores';
import PanelType from 'ee/monitoring/components/panel_type.vue'; import PanelType from 'ee/monitoring/components/panel_type.vue';
import AlertWidget from 'ee/monitoring/components/alert_widget.vue'; import AlertWidget from 'ee/monitoring/components/alert_widget.vue';
import { graphDataPrometheusQueryRange } from 'jest/monitoring/mock_data'; import { graphDataPrometheusQueryRange } from 'jest/monitoring/mock_data';
...@@ -12,9 +13,11 @@ localVue.use(Vuex); ...@@ -12,9 +13,11 @@ localVue.use(Vuex);
global.URL.createObjectURL = jest.fn(); global.URL.createObjectURL = jest.fn();
describe('Panel Type', () => { describe('Panel Type', () => {
let store;
let wrapper; let wrapper;
let metricsSavedToDbValue;
const setMetricsSavedToDb = val =>
monitoringDashboard.getters.metricsSavedToDb.mockReturnValue(val);
const findAlertsWidget = () => wrapper.find(AlertWidget); const findAlertsWidget = () => wrapper.find(AlertWidget);
const findMenuItemAlert = () => const findMenuItemAlert = () =>
wrapper.findAll(GlDropdownItem).filter(i => i.text() === 'Alerts'); wrapper.findAll(GlDropdownItem).filter(i => i.text() === 'Alerts');
...@@ -27,17 +30,6 @@ describe('Panel Type', () => { ...@@ -27,17 +30,6 @@ describe('Panel Type', () => {
}; };
const createWrapper = propsData => { const createWrapper = propsData => {
const store = new Vuex.Store({
modules: {
monitoringDashboard: {
namespaced: true,
getters: {
metricsSavedToDb: jest.fn().mockReturnValue(metricsSavedToDbValue),
},
},
},
});
wrapper = shallowMount(PanelType, { wrapper = shallowMount(PanelType, {
propsData: { propsData: {
...mockPropsData, ...mockPropsData,
...@@ -48,70 +40,38 @@ describe('Panel Type', () => { ...@@ -48,70 +40,38 @@ describe('Panel Type', () => {
}); });
}; };
describe('panel type alerts', () => {
describe('with license and no metrics in db', () => {
beforeEach(() => {
metricsSavedToDbValue = [];
createWrapper();
return wrapper.vm.$nextTick();
});
it('does not show an alert widget', () => {
expect(findAlertsWidget().exists()).toBe(false);
});
it('does not show menu for alert configuration', () => {
expect(findMenuItemAlert().exists()).toBe(false);
});
});
describe('with license and related metrics in db', () => {
beforeEach(() => { beforeEach(() => {
metricsSavedToDbValue = [graphDataPrometheusQueryRange.metrics[0].metricId]; jest.spyOn(monitoringDashboard.getters, 'metricsSavedToDb').mockReturnValue([]);
createWrapper();
return wrapper.vm.$nextTick();
});
it('shows an alert widget', () => {
expect(findAlertsWidget().exists()).toBe(true);
});
it('shows menu for alert configuration', () => { store = new Vuex.Store({
expect(findMenuItemAlert().exists()).toBe(true); modules: {
}); monitoringDashboard,
}); },
describe('with license and unrelated metrics in db', () => {
beforeEach(() => {
metricsSavedToDbValue = ['another_metric_id'];
createWrapper();
return wrapper.vm.$nextTick();
}); });
it('does not show an alert widget', () => {
expect(findAlertsWidget().exists()).toBe(false);
}); });
it('does not show menu for alert configuration', () => { describe('panel type alerts', () => {
expect(findMenuItemAlert().exists()).toBe(false); describe.each`
}); desc | metricsSavedToDb | propsData | isShown
}); ${'with license and no metrics in db'} | ${[]} | ${{}} | ${false}
${'with license and related metrics in db'} | ${[graphDataPrometheusQueryRange.metrics[0].metricId]} | ${{}} | ${true}
${'without license and related metrics in db'} | ${[graphDataPrometheusQueryRange.metrics[0].metricId]} | ${{ prometheusAlertsAvailable: false }} | ${false}
${'with license and unrelated metrics in db'} | ${['another_metric_id']} | ${{}} | ${false}
`('$desc', ({ metricsSavedToDb, isShown, propsData }) => {
const showsDesc = isShown ? 'shows' : 'does not show';
describe('without license and metrics in db', () => {
beforeEach(() => { beforeEach(() => {
metricsSavedToDbValue = [graphDataPrometheusQueryRange.metrics[0].metricId]; setMetricsSavedToDb(metricsSavedToDb);
createWrapper({ createWrapper(propsData);
prometheusAlertsAvailable: false,
});
return wrapper.vm.$nextTick(); return wrapper.vm.$nextTick();
}); });
it('does not show an alert widget', () => { it(`${showsDesc} alert widget`, () => {
expect(findAlertsWidget().exists()).toBe(false); expect(findAlertsWidget().exists()).toBe(isShown);
}); });
it('does not show menu for alert configuration', () => { it(`${showsDesc} alert configuration`, () => {
expect(findMenuItemAlert().exists()).toBe(false); expect(findMenuItemAlert().exists()).toBe(isShown);
}); });
}); });
}); });
......
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