Commit fc99e540 authored by Filipa Lacerda's avatar Filipa Lacerda

Merge branch 'ce-nfriend-fix-the-merge-button' into 'master'

CE backport for gitlab-org/gitlab-ee!14894: Fix the merge button dropdown

See merge request gitlab-org/gitlab-ce!31248
parents d1e80af6 eade5c06
...@@ -94,9 +94,6 @@ export default { ...@@ -94,9 +94,6 @@ export default {
return __('Merge'); return __('Merge');
}, },
shouldShowMergeOptionsDropdown() {
return this.isAutoMergeAvailable && !this.mr.onlyAllowMergeIfPipelineSucceeds;
},
isRemoveSourceBranchButtonDisabled() { isRemoveSourceBranchButtonDisabled() {
return this.isMergeButtonDisabled; return this.isMergeButtonDisabled;
}, },
...@@ -246,7 +243,7 @@ export default { ...@@ -246,7 +243,7 @@ export default {
{{ mergeButtonText }} {{ mergeButtonText }}
</button> </button>
<button <button
v-if="isAutoMergeAvailable" v-if="shouldShowMergeImmediatelyDropdown"
:disabled="isMergeButtonDisabled" :disabled="isMergeButtonDisabled"
type="button" type="button"
class="btn btn-sm btn-info dropdown-toggle js-merge-moment" class="btn btn-sm btn-info dropdown-toggle js-merge-moment"
...@@ -256,7 +253,7 @@ export default { ...@@ -256,7 +253,7 @@ export default {
<i class="fa fa-chevron-down qa-merge-moment-dropdown" aria-hidden="true"></i> <i class="fa fa-chevron-down qa-merge-moment-dropdown" aria-hidden="true"></i>
</button> </button>
<ul <ul
v-if="shouldShowMergeOptionsDropdown" v-if="shouldShowMergeImmediatelyDropdown"
class="dropdown-menu dropdown-menu-right" class="dropdown-menu dropdown-menu-right"
role="menu" role="menu"
> >
......
...@@ -15,5 +15,8 @@ export default { ...@@ -15,5 +15,8 @@ export default {
// MWPS is currently the only auto merge strategy available in CE // MWPS is currently the only auto merge strategy available in CE
return __('Merge when pipeline succeeds'); return __('Merge when pipeline succeeds');
}, },
shouldShowMergeImmediatelyDropdown() {
return this.mr.isPipelineActive && !this.mr.onlyAllowMergeIfPipelineSucceeds;
},
}, },
}; };
...@@ -236,24 +236,26 @@ describe('ReadyToMerge', () => { ...@@ -236,24 +236,26 @@ describe('ReadyToMerge', () => {
}); });
}); });
describe('shouldShowMergeOptionsDropdown', () => { describe('shouldShowMergeImmediatelyDropdown', () => {
it('should return false when no auto merge strategies are available', () => { it('should return false if no pipeline is active', () => {
Vue.set(vm.mr, 'availableAutoMergeStrategies', []); Vue.set(vm.mr, 'isPipelineActive', false);
Vue.set(vm.mr, 'onlyAllowMergeIfPipelineSucceeds', false);
expect(vm.shouldShowMergeOptionsDropdown).toBe(false); expect(vm.shouldShowMergeImmediatelyDropdown).toBe(false);
}); });
it('should return true when at least one auto merge strategy is available', () => { it('should return false if "Pipelines must succeed" is enabled for the current project', () => {
Vue.set(vm.mr, 'availableAutoMergeStrategies', [ATMTWPS_MERGE_STRATEGY]); Vue.set(vm.mr, 'isPipelineActive', true);
Vue.set(vm.mr, 'onlyAllowMergeIfPipelineSucceeds', true);
expect(vm.shouldShowMergeOptionsDropdown).toBe(true); expect(vm.shouldShowMergeImmediatelyDropdown).toBe(false);
}); });
it('should return false when pipeline active but only merge when pipeline succeeds set in project options', () => { it('should return true if the MR\'s pipeline is active and "Pipelines must succeed" is not enabled for the current project', () => {
Vue.set(vm.mr, 'availableAutoMergeStrategies', [ATMTWPS_MERGE_STRATEGY]); Vue.set(vm.mr, 'isPipelineActive', true);
Vue.set(vm.mr, 'onlyAllowMergeIfPipelineSucceeds', true); Vue.set(vm.mr, 'onlyAllowMergeIfPipelineSucceeds', false);
expect(vm.shouldShowMergeOptionsDropdown).toBe(false); expect(vm.shouldShowMergeImmediatelyDropdown).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