Commit 0052257c authored by Frédéric Caplette's avatar Frédéric Caplette

Merge branch '325182_01_vuex_in_specs' into 'master'

Geo Node Status 2.0 - Vuex Spec Cleanup

See merge request gitlab-org/gitlab!60151
parents 065153e6 14031b82
import { GlLink, GlButton, GlLoadingIcon, GlModal } from '@gitlab/ui'; import { GlLink, GlButton, GlLoadingIcon, GlModal } from '@gitlab/ui';
import { createLocalVue, shallowMount } from '@vue/test-utils'; import { shallowMount } from '@vue/test-utils';
import Vue from 'vue';
import Vuex from 'vuex'; import Vuex from 'vuex';
import GeoNodesBetaApp from 'ee/geo_nodes_beta/components/app.vue'; import GeoNodesBetaApp from 'ee/geo_nodes_beta/components/app.vue';
import GeoNodes from 'ee/geo_nodes_beta/components/geo_nodes.vue'; import GeoNodes from 'ee/geo_nodes_beta/components/geo_nodes.vue';
import GeoNodesEmptyState from 'ee/geo_nodes_beta/components/geo_nodes_empty_state.vue'; import GeoNodesEmptyState from 'ee/geo_nodes_beta/components/geo_nodes_empty_state.vue';
import { GEO_INFO_URL } from 'ee/geo_nodes_beta/constants'; import { GEO_INFO_URL } from 'ee/geo_nodes_beta/constants';
import { import { MOCK_NODES, MOCK_NEW_NODE_URL, MOCK_EMPTY_STATE_SVG } from '../mock_data';
MOCK_PRIMARY_VERSION,
MOCK_REPLICABLE_TYPES,
MOCK_NODES,
MOCK_NEW_NODE_URL,
MOCK_EMPTY_STATE_SVG,
} from '../mock_data';
const localVue = createLocalVue(); Vue.use(Vuex);
localVue.use(Vuex);
describe('GeoNodesBetaApp', () => { describe('GeoNodesBetaApp', () => {
let wrapper; let wrapper;
...@@ -33,16 +27,12 @@ describe('GeoNodesBetaApp', () => { ...@@ -33,16 +27,12 @@ describe('GeoNodesBetaApp', () => {
const createComponent = (initialState, props) => { const createComponent = (initialState, props) => {
const store = new Vuex.Store({ const store = new Vuex.Store({
state: { state: {
primaryVersion: MOCK_PRIMARY_VERSION.version,
primaryRevision: MOCK_PRIMARY_VERSION.revision,
replicableTypes: MOCK_REPLICABLE_TYPES,
...initialState, ...initialState,
}, },
actions: actionSpies, actions: actionSpies,
}); });
wrapper = shallowMount(GeoNodesBetaApp, { wrapper = shallowMount(GeoNodesBetaApp, {
localVue,
store, store,
propsData: { propsData: {
...defaultProps, ...defaultProps,
......
import { GlEmptyState } from '@gitlab/ui'; import { GlEmptyState } from '@gitlab/ui';
import { createLocalVue, shallowMount } from '@vue/test-utils'; import { shallowMount } from '@vue/test-utils';
import Vuex from 'vuex';
import GeoNodesEmptyState from 'ee/geo_nodes_beta/components/geo_nodes_empty_state.vue'; import GeoNodesEmptyState from 'ee/geo_nodes_beta/components/geo_nodes_empty_state.vue';
import { GEO_FEATURE_URL } from 'ee/geo_nodes_beta/constants'; import { GEO_FEATURE_URL } from 'ee/geo_nodes_beta/constants';
import { MOCK_PRIMARY_VERSION, MOCK_REPLICABLE_TYPES, MOCK_EMPTY_STATE_SVG } from '../mock_data'; import { MOCK_EMPTY_STATE_SVG } from '../mock_data';
const localVue = createLocalVue();
localVue.use(Vuex);
describe('GeoNodesEmptyState', () => { describe('GeoNodesEmptyState', () => {
let wrapper; let wrapper;
...@@ -15,19 +11,8 @@ describe('GeoNodesEmptyState', () => { ...@@ -15,19 +11,8 @@ describe('GeoNodesEmptyState', () => {
svgPath: MOCK_EMPTY_STATE_SVG, svgPath: MOCK_EMPTY_STATE_SVG,
}; };
const createComponent = (initialState, props) => { const createComponent = (props) => {
const store = new Vuex.Store({
state: {
primaryVersion: MOCK_PRIMARY_VERSION.version,
primaryRevision: MOCK_PRIMARY_VERSION.revision,
replicableTypes: MOCK_REPLICABLE_TYPES,
...initialState,
},
});
wrapper = shallowMount(GeoNodesEmptyState, { wrapper = shallowMount(GeoNodesEmptyState, {
localVue,
store,
propsData: { propsData: {
...defaultProps, ...defaultProps,
...props, ...props,
......
import { GlButton } from '@gitlab/ui'; import { GlButton } from '@gitlab/ui';
import { createLocalVue, shallowMount } from '@vue/test-utils'; import { shallowMount } from '@vue/test-utils';
import Vuex from 'vuex';
import GeoNodeActionsDesktop from 'ee/geo_nodes_beta/components/header/geo_node_actions_desktop.vue'; import GeoNodeActionsDesktop from 'ee/geo_nodes_beta/components/header/geo_node_actions_desktop.vue';
import { import { MOCK_NODES } from 'ee_jest/geo_nodes_beta/mock_data';
MOCK_NODES,
MOCK_PRIMARY_VERSION,
MOCK_REPLICABLE_TYPES,
} from 'ee_jest/geo_nodes_beta/mock_data';
import { extendedWrapper } from 'helpers/vue_test_utils_helper'; import { extendedWrapper } from 'helpers/vue_test_utils_helper';
const localVue = createLocalVue();
localVue.use(Vuex);
describe('GeoNodeActionsDesktop', () => { describe('GeoNodeActionsDesktop', () => {
let wrapper; let wrapper;
...@@ -19,20 +11,9 @@ describe('GeoNodeActionsDesktop', () => { ...@@ -19,20 +11,9 @@ describe('GeoNodeActionsDesktop', () => {
node: MOCK_NODES[0], node: MOCK_NODES[0],
}; };
const createComponent = (initialState, props) => { const createComponent = (props) => {
const store = new Vuex.Store({
state: {
primaryVersion: MOCK_PRIMARY_VERSION.version,
primaryRevision: MOCK_PRIMARY_VERSION.revision,
replicableTypes: MOCK_REPLICABLE_TYPES,
...initialState,
},
});
wrapper = extendedWrapper( wrapper = extendedWrapper(
shallowMount(GeoNodeActionsDesktop, { shallowMount(GeoNodeActionsDesktop, {
localVue,
store,
propsData: { propsData: {
...defaultProps, ...defaultProps,
...props, ...props,
...@@ -80,7 +61,7 @@ describe('GeoNodeActionsDesktop', () => { ...@@ -80,7 +61,7 @@ describe('GeoNodeActionsDesktop', () => {
${false} | ${undefined} ${false} | ${undefined}
`(`conditionally`, ({ primary, disabled }) => { `(`conditionally`, ({ primary, disabled }) => {
beforeEach(() => { beforeEach(() => {
createComponent(null, { node: { primary } }); createComponent({ node: { primary } });
}); });
describe(`when primary is ${primary}`, () => { describe(`when primary is ${primary}`, () => {
......
import { GlDropdown, GlDropdownItem } from '@gitlab/ui'; import { GlDropdown, GlDropdownItem } from '@gitlab/ui';
import { createLocalVue, shallowMount } from '@vue/test-utils'; import { shallowMount } from '@vue/test-utils';
import Vuex from 'vuex';
import GeoNodeActionsMobile from 'ee/geo_nodes_beta/components/header/geo_node_actions_mobile.vue'; import GeoNodeActionsMobile from 'ee/geo_nodes_beta/components/header/geo_node_actions_mobile.vue';
import { import { MOCK_NODES } from 'ee_jest/geo_nodes_beta/mock_data';
MOCK_NODES,
MOCK_PRIMARY_VERSION,
MOCK_REPLICABLE_TYPES,
} from 'ee_jest/geo_nodes_beta/mock_data';
import { extendedWrapper } from 'helpers/vue_test_utils_helper'; import { extendedWrapper } from 'helpers/vue_test_utils_helper';
const localVue = createLocalVue();
localVue.use(Vuex);
describe('GeoNodeActionsMobile', () => { describe('GeoNodeActionsMobile', () => {
let wrapper; let wrapper;
...@@ -19,20 +11,9 @@ describe('GeoNodeActionsMobile', () => { ...@@ -19,20 +11,9 @@ describe('GeoNodeActionsMobile', () => {
node: MOCK_NODES[0], node: MOCK_NODES[0],
}; };
const createComponent = (initialState, props) => { const createComponent = (props) => {
const store = new Vuex.Store({
state: {
primaryVersion: MOCK_PRIMARY_VERSION.version,
primaryRevision: MOCK_PRIMARY_VERSION.revision,
replicableTypes: MOCK_REPLICABLE_TYPES,
...initialState,
},
});
wrapper = extendedWrapper( wrapper = extendedWrapper(
shallowMount(GeoNodeActionsMobile, { shallowMount(GeoNodeActionsMobile, {
localVue,
store,
propsData: { propsData: {
...defaultProps, ...defaultProps,
...props, ...props,
...@@ -86,7 +67,7 @@ describe('GeoNodeActionsMobile', () => { ...@@ -86,7 +67,7 @@ describe('GeoNodeActionsMobile', () => {
${false} | ${undefined} | ${'gl-text-red-500'} ${false} | ${undefined} | ${'gl-text-red-500'}
`(`conditionally`, ({ primary, disabled, dropdownClass }) => { `(`conditionally`, ({ primary, disabled, dropdownClass }) => {
beforeEach(() => { beforeEach(() => {
createComponent(null, { node: { primary } }); createComponent({ node: { primary } });
}); });
describe(`when primary is ${primary}`, () => { describe(`when primary is ${primary}`, () => {
......
import { createLocalVue, shallowMount } from '@vue/test-utils'; import { shallowMount } from '@vue/test-utils';
import Vue from 'vue';
import Vuex from 'vuex'; import Vuex from 'vuex';
import GeoNodeActions from 'ee/geo_nodes_beta/components/header/geo_node_actions.vue'; import GeoNodeActions from 'ee/geo_nodes_beta/components/header/geo_node_actions.vue';
import GeoNodeActionsDesktop from 'ee/geo_nodes_beta/components/header/geo_node_actions_desktop.vue'; import GeoNodeActionsDesktop from 'ee/geo_nodes_beta/components/header/geo_node_actions_desktop.vue';
import GeoNodeActionsMobile from 'ee/geo_nodes_beta/components/header/geo_node_actions_mobile.vue'; import GeoNodeActionsMobile from 'ee/geo_nodes_beta/components/header/geo_node_actions_mobile.vue';
import { REMOVE_NODE_MODAL_ID } from 'ee/geo_nodes_beta/constants'; import { REMOVE_NODE_MODAL_ID } from 'ee/geo_nodes_beta/constants';
import { import { MOCK_NODES } from 'ee_jest/geo_nodes_beta/mock_data';
MOCK_NODES,
MOCK_PRIMARY_VERSION,
MOCK_REPLICABLE_TYPES,
} from 'ee_jest/geo_nodes_beta/mock_data';
import waitForPromises from 'helpers/wait_for_promises'; import waitForPromises from 'helpers/wait_for_promises';
import { BV_SHOW_MODAL } from '~/lib/utils/constants'; import { BV_SHOW_MODAL } from '~/lib/utils/constants';
const localVue = createLocalVue(); Vue.use(Vuex);
localVue.use(Vuex);
describe('GeoNodeActions', () => { describe('GeoNodeActions', () => {
let wrapper; let wrapper;
...@@ -26,19 +22,12 @@ describe('GeoNodeActions', () => { ...@@ -26,19 +22,12 @@ describe('GeoNodeActions', () => {
node: MOCK_NODES[0], node: MOCK_NODES[0],
}; };
const createComponent = (initialState, props) => { const createComponent = (props) => {
const store = new Vuex.Store({ const store = new Vuex.Store({
state: {
primaryVersion: MOCK_PRIMARY_VERSION.version,
primaryRevision: MOCK_PRIMARY_VERSION.revision,
replicableTypes: MOCK_REPLICABLE_TYPES,
...initialState,
},
actions: actionSpies, actions: actionSpies,
}); });
wrapper = shallowMount(GeoNodeActions, { wrapper = shallowMount(GeoNodeActions, {
localVue,
store, store,
propsData: { propsData: {
...defaultProps, ...defaultProps,
......
import { GlButton, GlBadge } from '@gitlab/ui'; import { GlButton, GlBadge } from '@gitlab/ui';
import { createLocalVue, shallowMount } from '@vue/test-utils'; import { shallowMount } from '@vue/test-utils';
import Vuex from 'vuex';
import GeoNodeActions from 'ee/geo_nodes_beta/components/header/geo_node_actions.vue'; import GeoNodeActions from 'ee/geo_nodes_beta/components/header/geo_node_actions.vue';
import GeoNodeHeader from 'ee/geo_nodes_beta/components/header/geo_node_header.vue'; import GeoNodeHeader from 'ee/geo_nodes_beta/components/header/geo_node_header.vue';
import GeoNodeHealthStatus from 'ee/geo_nodes_beta/components/header/geo_node_health_status.vue'; import GeoNodeHealthStatus from 'ee/geo_nodes_beta/components/header/geo_node_health_status.vue';
import GeoNodeLastUpdated from 'ee/geo_nodes_beta/components/header/geo_node_last_updated.vue'; import GeoNodeLastUpdated from 'ee/geo_nodes_beta/components/header/geo_node_last_updated.vue';
import { import { MOCK_NODES } from 'ee_jest/geo_nodes_beta/mock_data';
MOCK_PRIMARY_VERSION,
MOCK_REPLICABLE_TYPES,
MOCK_NODES,
} from 'ee_jest/geo_nodes_beta/mock_data';
const localVue = createLocalVue();
localVue.use(Vuex);
describe('GeoNodeHeader', () => { describe('GeoNodeHeader', () => {
let wrapper; let wrapper;
...@@ -22,19 +14,8 @@ describe('GeoNodeHeader', () => { ...@@ -22,19 +14,8 @@ describe('GeoNodeHeader', () => {
collapsed: false, collapsed: false,
}; };
const createComponent = (initialState, props) => { const createComponent = (props) => {
const store = new Vuex.Store({
state: {
primaryVersion: MOCK_PRIMARY_VERSION.version,
primaryRevision: MOCK_PRIMARY_VERSION.revision,
replicableTypes: MOCK_REPLICABLE_TYPES,
...initialState,
},
});
wrapper = shallowMount(GeoNodeHeader, { wrapper = shallowMount(GeoNodeHeader, {
localVue,
store,
propsData: { propsData: {
...defaultProps, ...defaultProps,
...props, ...props,
...@@ -84,7 +65,7 @@ describe('GeoNodeHeader', () => { ...@@ -84,7 +65,7 @@ describe('GeoNodeHeader', () => {
describe('when collapsed', () => { describe('when collapsed', () => {
beforeEach(() => { beforeEach(() => {
createComponent(null, { collapsed: true }); createComponent({ collapsed: true });
}); });
it('renders the chevron-right icon', () => { it('renders the chevron-right icon', () => {
...@@ -118,7 +99,7 @@ describe('GeoNodeHeader', () => { ...@@ -118,7 +99,7 @@ describe('GeoNodeHeader', () => {
describe('when current node is false', () => { describe('when current node is false', () => {
beforeEach(() => { beforeEach(() => {
createComponent(null, { node: MOCK_NODES[1] }); createComponent({ node: MOCK_NODES[1] });
}); });
it('does not render', () => { it('does not render', () => {
......
import { GlIcon, GlBadge } from '@gitlab/ui'; import { GlIcon, GlBadge } from '@gitlab/ui';
import { createLocalVue, shallowMount } from '@vue/test-utils'; import { shallowMount } from '@vue/test-utils';
import Vuex from 'vuex';
import GeoNodeHealthStatus from 'ee/geo_nodes_beta/components/header/geo_node_health_status.vue'; import GeoNodeHealthStatus from 'ee/geo_nodes_beta/components/header/geo_node_health_status.vue';
import { HEALTH_STATUS_UI } from 'ee/geo_nodes_beta/constants'; import { HEALTH_STATUS_UI } from 'ee/geo_nodes_beta/constants';
import { MOCK_PRIMARY_VERSION, MOCK_REPLICABLE_TYPES } from 'ee_jest/geo_nodes_beta/mock_data';
const localVue = createLocalVue();
localVue.use(Vuex);
describe('GeoNodeHealthStatus', () => { describe('GeoNodeHealthStatus', () => {
let wrapper; let wrapper;
...@@ -15,19 +10,8 @@ describe('GeoNodeHealthStatus', () => { ...@@ -15,19 +10,8 @@ describe('GeoNodeHealthStatus', () => {
status: 'Healthy', status: 'Healthy',
}; };
const createComponent = (initialState, props) => { const createComponent = (props) => {
const store = new Vuex.Store({
state: {
primaryVersion: MOCK_PRIMARY_VERSION.version,
primaryRevision: MOCK_PRIMARY_VERSION.revision,
replicableTypes: MOCK_REPLICABLE_TYPES,
...initialState,
},
});
wrapper = shallowMount(GeoNodeHealthStatus, { wrapper = shallowMount(GeoNodeHealthStatus, {
localVue,
store,
propsData: { propsData: {
...defaultProps, ...defaultProps,
...props, ...props,
...@@ -52,7 +36,7 @@ describe('GeoNodeHealthStatus', () => { ...@@ -52,7 +36,7 @@ describe('GeoNodeHealthStatus', () => {
${'Offline'} | ${HEALTH_STATUS_UI.offline} ${'Offline'} | ${HEALTH_STATUS_UI.offline}
`(`template`, ({ status, uiData }) => { `(`template`, ({ status, uiData }) => {
beforeEach(() => { beforeEach(() => {
createComponent(null, { status }); createComponent({ status });
}); });
describe(`when status is ${status}`, () => { describe(`when status is ${status}`, () => {
......
import { GlPopover, GlLink, GlIcon } from '@gitlab/ui'; import { GlPopover, GlLink, GlIcon } from '@gitlab/ui';
import { createLocalVue, shallowMount } from '@vue/test-utils'; import { shallowMount } from '@vue/test-utils';
import Vuex from 'vuex';
import GeoNodeLastUpdated from 'ee/geo_nodes_beta/components/header/geo_node_last_updated.vue'; import GeoNodeLastUpdated from 'ee/geo_nodes_beta/components/header/geo_node_last_updated.vue';
import { import {
HELP_NODE_HEALTH_URL, HELP_NODE_HEALTH_URL,
GEO_TROUBLESHOOTING_URL, GEO_TROUBLESHOOTING_URL,
STATUS_DELAY_THRESHOLD_MS, STATUS_DELAY_THRESHOLD_MS,
} from 'ee/geo_nodes_beta/constants'; } from 'ee/geo_nodes_beta/constants';
import { MOCK_PRIMARY_VERSION, MOCK_REPLICABLE_TYPES } from 'ee_jest/geo_nodes_beta/mock_data';
import { extendedWrapper } from 'helpers/vue_test_utils_helper'; import { extendedWrapper } from 'helpers/vue_test_utils_helper';
import { differenceInMilliseconds } from '~/lib/utils/datetime_utility'; import { differenceInMilliseconds } from '~/lib/utils/datetime_utility';
const localVue = createLocalVue();
localVue.use(Vuex);
describe('GeoNodeLastUpdated', () => { describe('GeoNodeLastUpdated', () => {
let wrapper; let wrapper;
...@@ -25,20 +20,9 @@ describe('GeoNodeLastUpdated', () => { ...@@ -25,20 +20,9 @@ describe('GeoNodeLastUpdated', () => {
statusCheckTimestamp: staleStatusTime, statusCheckTimestamp: staleStatusTime,
}; };
const createComponent = (initialState, props) => { const createComponent = (props) => {
const store = new Vuex.Store({
state: {
primaryVersion: MOCK_PRIMARY_VERSION.version,
primaryRevision: MOCK_PRIMARY_VERSION.revision,
replicableTypes: MOCK_REPLICABLE_TYPES,
...initialState,
},
});
wrapper = extendedWrapper( wrapper = extendedWrapper(
shallowMount(GeoNodeLastUpdated, { shallowMount(GeoNodeLastUpdated, {
localVue,
store,
propsData: { propsData: {
...defaultProps, ...defaultProps,
...props, ...props,
...@@ -95,7 +79,7 @@ describe('GeoNodeLastUpdated', () => { ...@@ -95,7 +79,7 @@ describe('GeoNodeLastUpdated', () => {
}); });
it('when sync is not stale popover link renders correctly', () => { it('when sync is not stale popover link renders correctly', () => {
createComponent(null, { statusCheckTimestamp: nonStaleStatusTime }); createComponent({ statusCheckTimestamp: nonStaleStatusTime });
expect(findPopoverLink().text()).toBe('Learn more about Geo node statuses'); expect(findPopoverLink().text()).toBe('Learn more about Geo node statuses');
expect(findPopoverLink().attributes('href')).toBe(HELP_NODE_HEALTH_URL); expect(findPopoverLink().attributes('href')).toBe(HELP_NODE_HEALTH_URL);
......
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