Commit be2075f1 authored by Zack Cuddy's avatar Zack Cuddy

Geo Sites - NA Verification Help

This change adds help text
to the Replication summary
when a NA verification type
exists.

This help text also links
to the docs.

Changelog: changed
EE: true
parent 55a4cc5a
<script> <script>
import { GlIcon, GlPopover, GlLink, GlButton } from '@gitlab/ui'; import { GlIcon, GlPopover, GlLink, GlButton, GlSprintf } from '@gitlab/ui';
import { mapGetters, mapState } from 'vuex'; import { mapGetters, mapState } from 'vuex';
import { GEO_REPLICATION_TYPES_URL } from 'ee/geo_nodes/constants'; import {
GEO_REPLICATION_TYPES_URL,
GEO_REPLICATION_SUPPORTED_TYPES_URL,
} from 'ee/geo_nodes/constants';
import { s__, __ } from '~/locale'; import { s__, __ } from '~/locale';
import GeoNodeReplicationDetailsResponsive from './geo_node_replication_details_responsive.vue'; import GeoNodeReplicationDetailsResponsive from './geo_node_replication_details_responsive.vue';
import GeoNodeReplicationStatusMobile from './geo_node_replication_status_mobile.vue'; import GeoNodeReplicationStatusMobile from './geo_node_replication_status_mobile.vue';
...@@ -12,12 +15,16 @@ export default { ...@@ -12,12 +15,16 @@ export default {
replicationDetails: s__('Geo|Replication Details'), replicationDetails: s__('Geo|Replication Details'),
popoverText: s__('Geo|Geo supports replication of many data types.'), popoverText: s__('Geo|Geo supports replication of many data types.'),
learnMore: __('Learn more'), learnMore: __('Learn more'),
naVerificationHelpText: s__(
'Geo|%{boldStart}N/A%{boldEnd}: Geo does not verify this component yet. See the %{linkStart}data types we plan to support%{linkEnd}.',
),
}, },
components: { components: {
GlIcon, GlIcon,
GlPopover, GlPopover,
GlLink, GlLink,
GlButton, GlButton,
GlSprintf,
GeoNodeReplicationDetailsResponsive, GeoNodeReplicationDetailsResponsive,
GeoNodeReplicationStatusMobile, GeoNodeReplicationStatusMobile,
}, },
...@@ -57,6 +64,9 @@ export default { ...@@ -57,6 +64,9 @@ export default {
chevronIcon() { chevronIcon() {
return this.collapsed ? 'chevron-right' : 'chevron-down'; return this.collapsed ? 'chevron-right' : 'chevron-down';
}, },
hasNAVerificationType() {
return this.replicationItems.some((item) => !item.verificationValues);
},
}, },
methods: { methods: {
collapseSection() { collapseSection() {
...@@ -64,6 +74,7 @@ export default { ...@@ -64,6 +74,7 @@ export default {
}, },
}, },
GEO_REPLICATION_TYPES_URL, GEO_REPLICATION_TYPES_URL,
GEO_REPLICATION_SUPPORTED_TYPES_URL,
}; };
</script> </script>
...@@ -119,6 +130,21 @@ export default { ...@@ -119,6 +130,21 @@ export default {
<geo-node-replication-status-mobile :item="item" :translations="translations" /> <geo-node-replication-status-mobile :item="item" :translations="translations" />
</template> </template>
</geo-node-replication-details-responsive> </geo-node-replication-details-responsive>
<div v-if="hasNAVerificationType" class="gl-mt-4">
<gl-sprintf :message="$options.i18n.naVerificationHelpText">
<template #bold="{ content }">
<span class="gl-font-weight-bold">{{ content }} </span>
</template>
<template #link="{ content }">
<gl-link
data-testid="naVerificationHelpLink"
:href="$options.GEO_REPLICATION_SUPPORTED_TYPES_URL"
target="_blank"
>{{ content }}
</gl-link>
</template>
</gl-sprintf>
</div>
</div> </div>
</div> </div>
</template> </template>
...@@ -27,6 +27,11 @@ export const GEO_REPLICATION_TYPES_URL = helpPagePath( ...@@ -27,6 +27,11 @@ export const GEO_REPLICATION_TYPES_URL = helpPagePath(
'administration/geo/replication/datatypes.html', 'administration/geo/replication/datatypes.html',
); );
export const GEO_REPLICATION_SUPPORTED_TYPES_URL = helpPagePath(
'administration/geo/replication/datatypes.html',
{ anchor: 'data-types' },
);
export const HEALTH_STATUS_UI = { export const HEALTH_STATUS_UI = {
healthy: { healthy: {
icon: 'status_success', icon: 'status_success',
......
import { GlIcon, GlPopover, GlLink, GlButton } from '@gitlab/ui'; import { GlIcon, GlPopover, GlLink, GlButton, GlSprintf } from '@gitlab/ui';
import { shallowMount } from '@vue/test-utils';
import Vue from 'vue'; import Vue from 'vue';
import Vuex from 'vuex'; import Vuex from 'vuex';
import { shallowMountExtended } from 'helpers/vue_test_utils_helper';
import GeoNodeReplicationDetails from 'ee/geo_nodes/components/details/secondary_node/geo_node_replication_details.vue'; import GeoNodeReplicationDetails from 'ee/geo_nodes/components/details/secondary_node/geo_node_replication_details.vue';
import GeoNodeReplicationDetailsResponsive from 'ee/geo_nodes/components/details/secondary_node/geo_node_replication_details_responsive.vue'; import GeoNodeReplicationDetailsResponsive from 'ee/geo_nodes/components/details/secondary_node/geo_node_replication_details_responsive.vue';
import GeoNodeReplicationStatusMobile from 'ee/geo_nodes/components/details/secondary_node/geo_node_replication_status_mobile.vue'; import GeoNodeReplicationStatusMobile from 'ee/geo_nodes/components/details/secondary_node/geo_node_replication_status_mobile.vue';
import { GEO_REPLICATION_TYPES_URL } from 'ee/geo_nodes/constants'; import {
GEO_REPLICATION_TYPES_URL,
GEO_REPLICATION_SUPPORTED_TYPES_URL,
} from 'ee/geo_nodes/constants';
import { MOCK_NODES, MOCK_REPLICABLE_TYPES } from 'ee_jest/geo_nodes/mock_data'; import { MOCK_NODES, MOCK_REPLICABLE_TYPES } from 'ee_jest/geo_nodes/mock_data';
import { extendedWrapper } from 'helpers/vue_test_utils_helper';
Vue.use(Vuex); Vue.use(Vuex);
...@@ -31,16 +33,14 @@ describe('GeoNodeReplicationDetails', () => { ...@@ -31,16 +33,14 @@ describe('GeoNodeReplicationDetails', () => {
}, },
}); });
wrapper = extendedWrapper( wrapper = shallowMountExtended(GeoNodeReplicationDetails, {
shallowMount(GeoNodeReplicationDetails, { store,
store, propsData: {
propsData: { ...defaultProps,
...defaultProps, ...props,
...props, },
}, stubs: { GeoNodeReplicationDetailsResponsive, GlSprintf },
stubs: { GeoNodeReplicationDetailsResponsive }, });
}),
);
}; };
afterEach(() => { afterEach(() => {
...@@ -57,6 +57,7 @@ describe('GeoNodeReplicationDetails', () => { ...@@ -57,6 +57,7 @@ describe('GeoNodeReplicationDetails', () => {
const findGlPopover = () => wrapper.findComponent(GlPopover); const findGlPopover = () => wrapper.findComponent(GlPopover);
const findGlPopoverLink = () => findGlPopover().findComponent(GlLink); const findGlPopoverLink = () => findGlPopover().findComponent(GlLink);
const findCollapseButton = () => wrapper.findComponent(GlButton); const findCollapseButton = () => wrapper.findComponent(GlButton);
const findNAVerificationHelpLink = () => wrapper.findByTestId('naVerificationHelpLink');
describe('template', () => { describe('template', () => {
describe('always', () => { describe('always', () => {
...@@ -105,6 +106,12 @@ describe('GeoNodeReplicationDetails', () => { ...@@ -105,6 +106,12 @@ describe('GeoNodeReplicationDetails', () => {
'gl-md-display-block', 'gl-md-display-block',
]); ]);
}); });
it('renders N/A Verification Help Text with correct link', () => {
expect(findNAVerificationHelpLink().attributes('href')).toBe(
GEO_REPLICATION_SUPPORTED_TYPES_URL,
);
});
}); });
describe('when collapsed', () => { describe('when collapsed', () => {
...@@ -168,30 +175,37 @@ describe('GeoNodeReplicationDetails', () => { ...@@ -168,30 +175,37 @@ describe('GeoNodeReplicationDetails', () => {
}; };
describe.each` describe.each`
description | mockSyncData | mockVerificationData | expectedProps description | mockSyncData | mockVerificationData | expectedProps | hasNAVerificationHelpText
${'with no data'} | ${[]} | ${[]} | ${[mockExpectedNoValues]} ${'with no data'} | ${[]} | ${[]} | ${[mockExpectedNoValues]} | ${true}
${'with no verification data'} | ${[mockSync]} | ${[]} | ${[mockExpectedOnlySync]} ${'with no verification data'} | ${[mockSync]} | ${[]} | ${[mockExpectedOnlySync]} | ${true}
${'with no sync data'} | ${[]} | ${[mockVerif]} | ${[mockExpectedOnlyVerif]} ${'with no sync data'} | ${[]} | ${[mockVerif]} | ${[mockExpectedOnlyVerif]} | ${false}
${'with all data'} | ${[mockSync]} | ${[mockVerif]} | ${[mockExpectedBothTypes]} ${'with all data'} | ${[mockSync]} | ${[mockVerif]} | ${[mockExpectedBothTypes]} | ${false}
`('$description', ({ mockSyncData, mockVerificationData, expectedProps }) => { `(
beforeEach(() => { '$description',
createComponent({ replicableTypes: [MOCK_REPLICABLE_TYPES[0]] }, null, { ({ mockSyncData, mockVerificationData, expectedProps, hasNAVerificationHelpText }) => {
syncInfo: () => () => mockSyncData, beforeEach(() => {
verificationInfo: () => () => mockVerificationData, createComponent({ replicableTypes: [MOCK_REPLICABLE_TYPES[0]] }, null, {
syncInfo: () => () => mockSyncData,
verificationInfo: () => () => mockVerificationData,
});
}); });
});
it('passes the correct props to the mobile replication details', () => { it('passes the correct props to the mobile replication details', () => {
expect(findGeoMobileReplicationDetails().props('replicationItems')).toStrictEqual( expect(findGeoMobileReplicationDetails().props('replicationItems')).toStrictEqual(
expectedProps, expectedProps,
); );
}); });
it('passes the correct props to the desktop replication details', () => { it('passes the correct props to the desktop replication details', () => {
expect(findGeoDesktopReplicationDetails().props('replicationItems')).toStrictEqual( expect(findGeoDesktopReplicationDetails().props('replicationItems')).toStrictEqual(
expectedProps, expectedProps,
); );
}); });
});
it(`does ${hasNAVerificationHelpText ? '' : 'not '}show N/A verification help text`, () => {
expect(findNAVerificationHelpLink().exists()).toBe(hasNAVerificationHelpText);
});
},
);
}); });
}); });
...@@ -15686,6 +15686,9 @@ msgstr "" ...@@ -15686,6 +15686,9 @@ msgstr ""
msgid "Geo sites" msgid "Geo sites"
msgstr "" msgstr ""
msgid "Geo|%{boldStart}N/A%{boldEnd}: Geo does not verify this component yet. See the %{linkStart}data types we plan to support%{linkEnd}."
msgstr ""
msgid "Geo|%{component} synced" msgid "Geo|%{component} synced"
msgstr "" msgstr ""
......
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