Commit 7c41df0d authored by Martin Wortschack's avatar Martin Wortschack Committed by Brandon Labuschagne

Use GlSprintf in deployment rollback modal

parent 73bd174d
<script> <script>
/* eslint-disable vue/no-v-html */
/** /**
* Render modal to confirm rollback/redeploy. * Render modal to confirm rollback/redeploy.
*/ */
import { GlModal, GlSprintf, GlLink } from '@gitlab/ui';
import { GlModal } from '@gitlab/ui';
import { escape } from 'lodash'; import { escape } from 'lodash';
import csrf from '~/lib/utils/csrf'; import csrf from '~/lib/utils/csrf';
import { __, s__, sprintf } from '~/locale'; import { __, s__, sprintf } from '~/locale';
...@@ -13,9 +11,10 @@ import eventHub from '../event_hub'; ...@@ -13,9 +11,10 @@ import eventHub from '../event_hub';
export default { export default {
name: 'ConfirmRollbackModal', name: 'ConfirmRollbackModal',
components: { components: {
GlModal, GlModal,
GlSprintf,
GlLink,
}, },
model: { model: {
prop: 'visible', prop: 'visible',
...@@ -42,7 +41,6 @@ export default { ...@@ -42,7 +41,6 @@ export default {
default: null, default: null,
}, },
}, },
computed: { computed: {
modalTitle() { modalTitle() {
const title = this.environment.isLastDeployment const title = this.environment.isLastDeployment
...@@ -53,7 +51,6 @@ export default { ...@@ -53,7 +51,6 @@ export default {
name: escape(this.environment.name), name: escape(this.environment.name),
}); });
}, },
commitShortSha() { commitShortSha() {
if (this.hasMultipleCommits) { if (this.hasMultipleCommits) {
const { last_deployment } = this.environment; const { last_deployment } = this.environment;
...@@ -62,7 +59,6 @@ export default { ...@@ -62,7 +59,6 @@ export default {
return this.environment.commitShortSha; return this.environment.commitShortSha;
}, },
commitUrl() { commitUrl() {
if (this.hasMultipleCommits) { if (this.hasMultipleCommits) {
const { last_deployment } = this.environment; const { last_deployment } = this.environment;
...@@ -71,37 +67,11 @@ export default { ...@@ -71,37 +67,11 @@ export default {
return this.environment.commitUrl; return this.environment.commitUrl;
}, },
modalActionText() { modalActionText() {
return this.environment.isLastDeployment return this.environment.isLastDeployment
? s__('Environments|Re-deploy') ? s__('Environments|Re-deploy')
: s__('Environments|Rollback'); : s__('Environments|Rollback');
}, },
modalText() {
const linkStart = `<a class="commit-sha mr-0" href="${escape(this.commitUrl)}">`;
const commitId = escape(this.commitShortSha);
const linkEnd = '</a>';
const name = escape(this.environment.name);
const body = this.environment.isLastDeployment
? s__(
'Environments|This action will relaunch the job for commit %{linkStart}%{commitId}%{linkEnd}, putting the environment in a previous version. Are you sure you want to continue?',
)
: s__(
'Environments|This action will run the job defined by %{name} for commit %{linkStart}%{commitId}%{linkEnd} putting the environment in a previous version. You can revert it by re-deploying the latest version of your application. Are you sure you want to continue?',
);
return sprintf(
body,
{
commitId,
linkStart,
linkEnd,
name,
},
false,
);
},
primaryProps() { primaryProps() {
let attributes = [{ variant: 'danger' }]; let attributes = [{ variant: 'danger' }];
...@@ -115,16 +85,13 @@ export default { ...@@ -115,16 +85,13 @@ export default {
}; };
}, },
}, },
methods: { methods: {
handleChange(event) { handleChange(event) {
this.$emit('change', event); this.$emit('change', event);
}, },
onOk() { onOk() {
eventHub.$emit('rollbackEnvironment', this.environment); eventHub.$emit('rollbackEnvironment', this.environment);
}, },
commitData(lastDeployment, key) { commitData(lastDeployment, key) {
if (lastDeployment && lastDeployment.commit) { if (lastDeployment && lastDeployment.commit) {
return lastDeployment.commit[key]; return lastDeployment.commit[key];
...@@ -150,6 +117,34 @@ export default { ...@@ -150,6 +117,34 @@ export default {
@ok="onOk" @ok="onOk"
@change="handleChange" @change="handleChange"
> >
<p v-html="modalText"></p> <gl-sprintf
v-if="environment.isLastDeployment"
:message="
s__(
'Environments|This action will relaunch the job for commit %{linkStart}%{commitId}%{linkEnd}, putting the environment in a previous version. Are you sure you want to continue?',
)
"
>
<template #link>
<gl-link :href="commitUrl" target="_blank" class="commit-sha mr-0">{{
commitShortSha
}}</gl-link>
</template>
</gl-sprintf>
<gl-sprintf
v-else
:message="
s__(
'Environments|This action will run the job defined by %{name} for commit %{linkStart}%{commitId}%{linkEnd} putting the environment in a previous version. You can revert it by re-deploying the latest version of your application. Are you sure you want to continue?',
)
"
>
<template #name>{{ environment.name }}</template>
<template #link>
<gl-link :href="commitUrl" target="_blank" class="commit-sha mr-0">{{
commitShortSha
}}</gl-link>
</template>
</gl-sprintf>
</gl-modal> </gl-modal>
</template> </template>
import { GlModal } from '@gitlab/ui'; import { GlModal, GlSprintf } from '@gitlab/ui';
import { shallowMount } from '@vue/test-utils'; import { shallowMount } from '@vue/test-utils';
import ConfirmRollbackModal from '~/environments/components/confirm_rollback_modal.vue'; import ConfirmRollbackModal from '~/environments/components/confirm_rollback_modal.vue';
import eventHub from '~/environments/event_hub'; import eventHub from '~/environments/event_hub';
describe('Confirm Rollback Modal Component', () => { describe('Confirm Rollback Modal Component', () => {
let environment; let environment;
let component;
const envWithLastDeployment = { const envWithLastDeployment = {
name: 'test', name: 'test',
...@@ -25,6 +26,17 @@ describe('Confirm Rollback Modal Component', () => { ...@@ -25,6 +26,17 @@ describe('Confirm Rollback Modal Component', () => {
const retryPath = 'test/-/jobs/123/retry'; const retryPath = 'test/-/jobs/123/retry';
const createComponent = (props = {}) => {
component = shallowMount(ConfirmRollbackModal, {
propsData: {
...props,
},
stubs: {
GlSprintf,
},
});
};
describe.each` describe.each`
hasMultipleCommits | environmentData | retryUrl | primaryPropsAttrs hasMultipleCommits | environmentData | retryUrl | primaryPropsAttrs
${true} | ${envWithLastDeployment} | ${null} | ${[{ variant: 'danger' }]} ${true} | ${envWithLastDeployment} | ${null} | ${[{ variant: 'danger' }]}
...@@ -37,15 +49,13 @@ describe('Confirm Rollback Modal Component', () => { ...@@ -37,15 +49,13 @@ describe('Confirm Rollback Modal Component', () => {
}); });
it('should show "Rollback" when isLastDeployment is false', () => { it('should show "Rollback" when isLastDeployment is false', () => {
const component = shallowMount(ConfirmRollbackModal, { createComponent({
propsData: {
environment: { environment: {
...environment, ...environment,
isLastDeployment: false, isLastDeployment: false,
}, },
hasMultipleCommits, hasMultipleCommits,
retryUrl, retryUrl,
},
}); });
const modal = component.find(GlModal); const modal = component.find(GlModal);
...@@ -58,15 +68,14 @@ describe('Confirm Rollback Modal Component', () => { ...@@ -58,15 +68,14 @@ describe('Confirm Rollback Modal Component', () => {
}); });
it('should show "Re-deploy" when isLastDeployment is true', () => { it('should show "Re-deploy" when isLastDeployment is true', () => {
const component = shallowMount(ConfirmRollbackModal, { createComponent({
propsData: {
environment: { environment: {
...environment, ...environment,
isLastDeployment: true, isLastDeployment: true,
}, },
hasMultipleCommits, hasMultipleCommits,
},
}); });
const modal = component.find(GlModal); const modal = component.find(GlModal);
expect(modal.attributes('title')).toContain('Re-deploy'); expect(modal.attributes('title')).toContain('Re-deploy');
...@@ -78,12 +87,12 @@ describe('Confirm Rollback Modal Component', () => { ...@@ -78,12 +87,12 @@ describe('Confirm Rollback Modal Component', () => {
it('should emit the "rollback" event when "ok" is clicked', () => { it('should emit the "rollback" event when "ok" is clicked', () => {
const env = { ...environmentData, isLastDeployment: true }; const env = { ...environmentData, isLastDeployment: true };
const component = shallowMount(ConfirmRollbackModal, {
propsData: { createComponent({
environment: env, environment: env,
hasMultipleCommits, hasMultipleCommits,
},
}); });
const eventHubSpy = jest.spyOn(eventHub, '$emit'); const eventHubSpy = jest.spyOn(eventHub, '$emit');
const modal = component.find(GlModal); const modal = component.find(GlModal);
modal.vm.$emit('ok'); modal.vm.$emit('ok');
......
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