Commit 2c6b6085 authored by pburdette's avatar pburdette Committed by Payton Burdette

Change pipeline failed message

Change message for failed pipeline
on MR widget. And convert the spec
to vue test utils.
parent 8b4c3352
<script> <script>
import { GlLink, GlSprintf } from '@gitlab/ui';
import { s__ } from '~/locale';
import { helpPagePath } from '~/helpers/help_page_helper';
import statusIcon from '../mr_widget_status_icon.vue'; import statusIcon from '../mr_widget_status_icon.vue';
export default { export default {
name: 'PipelineFailed', name: 'PipelineFailed',
components: { components: {
GlLink,
GlSprintf,
statusIcon, statusIcon,
}, },
computed: {
troubleshootingDocsPath() {
return helpPagePath('ci/troubleshooting', { anchor: 'merge-request-status-messages' });
},
failedMessage() {
return s__(
`mrWidget|The pipeline for this merge request did not complete. Push a new commit to fix the failure or check the %{linkStart}troubleshooting documentation%{linkEnd} to see other possible actions.`,
);
},
},
}; };
</script> </script>
...@@ -14,10 +29,13 @@ export default { ...@@ -14,10 +29,13 @@ export default {
<status-icon :show-disabled-button="true" status="warning" /> <status-icon :show-disabled-button="true" status="warning" />
<div class="media-body space-children"> <div class="media-body space-children">
<span class="bold"> <span class="bold">
{{ <gl-sprintf :message="failedMessage">
s__(`mrWidget|The pipeline for this merge request failed. <template #link="{ content }">
Please retry the job or push a new commit to fix the failure`) <gl-link :href="troubleshootingDocsPath" target="_blank">
}} {{ content }}
</gl-link>
</template>
</gl-sprintf>
</span> </span>
</div> </div>
</div> </div>
......
---
title: Change UI text for failed pipeline on an MR
merge_request: 52023
author:
type: changed
...@@ -222,6 +222,10 @@ This also applies if the pipeline has not been created yet, or if you are waitin ...@@ -222,6 +222,10 @@ This also applies if the pipeline has not been created yet, or if you are waitin
for an external CI service. If you don't use pipelines for your project, then you for an external CI service. If you don't use pipelines for your project, then you
should disable **Pipelines must succeed** so you can accept merge requests. should disable **Pipelines must succeed** so you can accept merge requests.
### "The pipeline for this merge request did not complete. Push a new commit to fix the failure or check the troubleshooting documentation to see other possible actions." message
This message is shown if the merge request pipeline or merge train pipeline has either failed or been canceled. If the merge train pipeline has failed, check the failure and determine if you need to re-add the MR to the train or push a commit to fix the failure. If the merge train pipeline was canceled try re-adding it to the train or use the shortcut command `/merge`. If the merge request pipeline was canceled or failed, please retry the job or push a new commit to fix the failure.
## Pipeline warnings ## Pipeline warnings
Pipeline configuration warnings are shown when you: Pipeline configuration warnings are shown when you:
......
...@@ -34167,7 +34167,7 @@ msgstr "" ...@@ -34167,7 +34167,7 @@ msgstr ""
msgid "mrWidget|The changes will be merged into" msgid "mrWidget|The changes will be merged into"
msgstr "" msgstr ""
msgid "mrWidget|The pipeline for this merge request failed. Please retry the job or push a new commit to fix the failure" msgid "mrWidget|The pipeline for this merge request did not complete. Push a new commit to fix the failure or check the %{linkStart}troubleshooting documentation%{linkEnd} to see other possible actions."
msgstr "" msgstr ""
msgid "mrWidget|The source branch HEAD has recently changed. Please reload the page and review the changes before merging" msgid "mrWidget|The source branch HEAD has recently changed. Please reload the page and review the changes before merging"
......
...@@ -57,7 +57,7 @@ RSpec.describe 'Merge request > User merges only if pipeline succeeds', :js do ...@@ -57,7 +57,7 @@ RSpec.describe 'Merge request > User merges only if pipeline succeeds', :js do
wait_for_requests wait_for_requests
expect(page).to have_css('button[disabled="disabled"]', text: 'Merge') expect(page).to have_css('button[disabled="disabled"]', text: 'Merge')
expect(page).to have_content('Please retry the job or push a new commit to fix the failure') expect(page).to have_content('The pipeline for this merge request did not complete. Push a new commit to fix the failure or check the troubleshooting documentation to see other possible actions.')
end end
end end
...@@ -70,7 +70,7 @@ RSpec.describe 'Merge request > User merges only if pipeline succeeds', :js do ...@@ -70,7 +70,7 @@ RSpec.describe 'Merge request > User merges only if pipeline succeeds', :js do
wait_for_requests wait_for_requests
expect(page).not_to have_button 'Merge' expect(page).not_to have_button 'Merge'
expect(page).to have_content('Please retry the job or push a new commit to fix the failure') expect(page).to have_content('The pipeline for this merge request did not complete. Push a new commit to fix the failure or check the troubleshooting documentation to see other possible actions.')
end end
end end
......
// Jest Snapshot v1, https://goo.gl/fbAQLP
exports[`PipelineFailed should display correctly 1`] = `
<div
class="mr-widget-body media"
>
<status-icon-stub
showdisabledbutton="true"
status="warning"
/>
<div
class="media-body space-children"
>
<span
class="bold"
>
<gl-sprintf-stub
message="The pipeline for this merge request did not complete. Push a new commit to fix the failure or check the %{linkStart}troubleshooting documentation%{linkEnd} to see other possible actions."
/>
</span>
</div>
</div>
`;
import Vue from 'vue'; import { shallowMount } from '@vue/test-utils';
import { removeBreakLine } from 'helpers/text_helper';
import PipelineFailed from '~/vue_merge_request_widget/components/states/pipeline_failed.vue'; import PipelineFailed from '~/vue_merge_request_widget/components/states/pipeline_failed.vue';
import statusIcon from '~/vue_merge_request_widget/components/mr_widget_status_icon.vue';
describe('PipelineFailed', () => { describe('PipelineFailed', () => {
describe('template', () => { let wrapper;
const Component = Vue.extend(PipelineFailed);
const vm = new Component({ const createComponent = () => {
el: document.createElement('div'), wrapper = shallowMount(PipelineFailed);
};
const findStatusIcon = () => wrapper.find(statusIcon);
beforeEach(() => {
createComponent();
}); });
it('should have correct elements', () => {
expect(vm.$el.classList.contains('mr-widget-body')).toBeTruthy(); afterEach(() => {
expect(vm.$el.querySelector('button').getAttribute('disabled')).toBeTruthy(); wrapper.destroy();
expect(removeBreakLine(vm.$el.innerText).trim()).toContain( wrapper = null;
'The pipeline for this merge request failed. Please retry the job or push a new commit to fix the failure',
);
}); });
it('should display correctly', () => {
expect(wrapper.element).toMatchSnapshot();
});
it('merge button should be disabled', () => {
expect(findStatusIcon().props('showDisabledButton')).toBe(true);
}); });
}); });
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