Commit 4d25c764 authored by Natalia Tepluhina's avatar Natalia Tepluhina

Merge branch '35917-ux-start-merge-train-failed-update' into 'master'

Add danger variant for merge trains and message

See merge request gitlab-org/gitlab!63094
parents 7535be32 a7337266
...@@ -22,7 +22,13 @@ import { __ } from '~/locale'; ...@@ -22,7 +22,13 @@ import { __ } from '~/locale';
import SmartInterval from '~/smart_interval'; import SmartInterval from '~/smart_interval';
import glFeatureFlagMixin from '~/vue_shared/mixins/gl_feature_flags_mixin'; import glFeatureFlagMixin from '~/vue_shared/mixins/gl_feature_flags_mixin';
import MergeRequest from '../../../merge_request'; import MergeRequest from '../../../merge_request';
import { AUTO_MERGE_STRATEGIES, DANGER, CONFIRM, WARNING } from '../../constants'; import {
AUTO_MERGE_STRATEGIES,
DANGER,
CONFIRM,
WARNING,
MT_MERGE_STRATEGY,
} from '../../constants';
import eventHub from '../../event_hub'; import eventHub from '../../event_hub';
import mergeRequestQueryVariablesMixin from '../../mixins/merge_request_query_variables'; import mergeRequestQueryVariablesMixin from '../../mixins/merge_request_query_variables';
import MergeRequestStore from '../../stores/mr_widget_store'; import MergeRequestStore from '../../stores/mr_widget_store';
...@@ -223,7 +229,7 @@ export default { ...@@ -223,7 +229,7 @@ export default {
return PIPELINE_SUCCESS_STATE; return PIPELINE_SUCCESS_STATE;
}, },
mergeButtonVariant() { mergeButtonVariant() {
if (this.status === PIPELINE_FAILED_STATE) { if (this.status === PIPELINE_FAILED_STATE || this.isPipelineFailed) {
return DANGER; return DANGER;
} }
...@@ -286,6 +292,9 @@ export default { ...@@ -286,6 +292,9 @@ export default {
shaMismatchLink() { shaMismatchLink() {
return this.mr.mergeRequestDiffsPath; return this.mr.mergeRequestDiffsPath;
}, },
showDangerMessageForMergeTrain() {
return this.preferredAutoMergeStrategy === MT_MERGE_STRATEGY && this.isPipelineFailed;
},
}, },
mounted() { mounted() {
if (this.glFeatures.mergeRequestWidgetGraphql) { if (this.glFeatures.mergeRequestWidgetGraphql) {
...@@ -499,7 +508,7 @@ export default { ...@@ -499,7 +508,7 @@ export default {
v-if="shouldShowMergeImmediatelyDropdown" v-if="shouldShowMergeImmediatelyDropdown"
v-gl-tooltip.hover.focus="__('Select merge moment')" v-gl-tooltip.hover.focus="__('Select merge moment')"
:disabled="isMergeButtonDisabled" :disabled="isMergeButtonDisabled"
variant="info" :variant="mergeButtonVariant"
data-qa-selector="merge_moment_dropdown" data-qa-selector="merge_moment_dropdown"
toggle-class="btn-icon js-merge-moment" toggle-class="btn-icon js-merge-moment"
> >
...@@ -579,6 +588,14 @@ export default { ...@@ -579,6 +588,14 @@ export default {
</gl-sprintf> </gl-sprintf>
</span> </span>
</div> </div>
<div
v-if="showDangerMessageForMergeTrain"
class="gl-mt-5 gl-text-gray-500"
data-testid="failed-pipeline-merge-train-text"
>
{{ __('The latest pipeline for this merge request did not complete successfully.') }}
</div>
</div> </div>
</div> </div>
<merge-train-helper-text <merge-train-helper-text
......
...@@ -86,6 +86,8 @@ describe('ReadyToMerge', () => { ...@@ -86,6 +86,8 @@ describe('ReadyToMerge', () => {
findMergeTrainHelperText().find('[data-testid="pipeline-link"]'); findMergeTrainHelperText().find('[data-testid="pipeline-link"]');
const findMergeTrainDocumentationLink = () => const findMergeTrainDocumentationLink = () =>
findMergeTrainHelperText().find('[data-testid="documentation-link"]'); findMergeTrainHelperText().find('[data-testid="documentation-link"]');
const findFailedPipelineMergeTrainText = () =>
wrapper.find('[data-testid="failed-pipeline-merge-train-text"]');
afterEach(() => { afterEach(() => {
if (wrapper?.destroy) { if (wrapper?.destroy) {
...@@ -423,4 +425,32 @@ describe('ReadyToMerge', () => { ...@@ -423,4 +425,32 @@ describe('ReadyToMerge', () => {
expect(findPipelineConflictMessage().text()).toBe(PIPELINE_MUST_SUCCEED_CONFLICT_TEXT); expect(findPipelineConflictMessage().text()).toBe(PIPELINE_MUST_SUCCEED_CONFLICT_TEXT);
}); });
}); });
describe('Merge button variant', () => {
it('danger variant and failed text should show if pipeline failed', () => {
factory({
isPipelineFailed: true,
preferredAutoMergeStrategy: MT_MERGE_STRATEGY,
availableAutoMergeStrategies: [MT_MERGE_STRATEGY],
hasCI: true,
onlyAllowMergeIfPipelineSucceeds: false,
});
expect(findMergeButton().attributes('variant')).toBe('danger');
expect(findFailedPipelineMergeTrainText().exists()).toBe(true);
});
it('confirm variant and failed text should not show if pipeline passed', () => {
factory({
preferredAutoMergeStrategy: MT_MERGE_STRATEGY,
availableAutoMergeStrategies: [MT_MERGE_STRATEGY],
hasCI: true,
onlyAllowMergeIfPipelineSucceeds: false,
ciStatus: 'success',
});
expect(findMergeButton().attributes('variant')).toBe('confirm');
expect(findFailedPipelineMergeTrainText().exists()).toBe(false);
});
});
}); });
...@@ -32625,6 +32625,9 @@ msgstr "" ...@@ -32625,6 +32625,9 @@ msgstr ""
msgid "The latest artifacts created by jobs in the most recent successful pipeline will be stored." msgid "The latest artifacts created by jobs in the most recent successful pipeline will be stored."
msgstr "" msgstr ""
msgid "The latest pipeline for this merge request did not complete successfully."
msgstr ""
msgid "The license key is invalid. Make sure it is exactly as you received it from GitLab Inc." msgid "The license key is invalid. Make sure it is exactly as you received it from GitLab Inc."
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