Commit 983cb647 authored by Martin Wortschack's avatar Martin Wortschack

Merge branch 'ph/207121/shaMismatchCanMerge' into 'master'

Fixes merge button showing incorrectly

Closes #207121

See merge request gitlab-org/gitlab!30278
parents 7f048afe cd5f60b5
...@@ -21,7 +21,7 @@ export default function deviseState(data) { ...@@ -21,7 +21,7 @@ export default function deviseState(data) {
return stateKey.unresolvedDiscussions; return stateKey.unresolvedDiscussions;
} else if (this.isPipelineBlocked) { } else if (this.isPipelineBlocked) {
return stateKey.pipelineBlocked; return stateKey.pipelineBlocked;
} else if (this.isSHAMismatch) { } else if (this.canMerge && this.isSHAMismatch) {
return stateKey.shaMismatch; return stateKey.shaMismatch;
} else if (this.autoMergeEnabled) { } else if (this.autoMergeEnabled) {
return this.mergeError ? stateKey.autoMergeFailed : stateKey.autoMergeEnabled; return this.mergeError ? stateKey.autoMergeFailed : stateKey.autoMergeEnabled;
......
---
title: Fixed enabled merge button incorrectly showing to users who can't merge
merge_request:
author:
type: fixed
...@@ -35,10 +35,12 @@ describe('getStateKey', () => { ...@@ -35,10 +35,12 @@ describe('getStateKey', () => {
expect(bound()).toEqual('autoMergeEnabled'); expect(bound()).toEqual('autoMergeEnabled');
context.canMerge = true;
context.isSHAMismatch = true; context.isSHAMismatch = true;
expect(bound()).toEqual('shaMismatch'); expect(bound()).toEqual('shaMismatch');
context.canMerge = false;
context.isPipelineBlocked = true; context.isPipelineBlocked = true;
expect(bound()).toEqual('pipelineBlocked'); expect(bound()).toEqual('pipelineBlocked');
...@@ -100,4 +102,26 @@ describe('getStateKey', () => { ...@@ -100,4 +102,26 @@ describe('getStateKey', () => {
expect(bound()).toEqual('rebase'); expect(bound()).toEqual('rebase');
}); });
it.each`
canMerge | isSHAMismatch | stateKey
${true} | ${true} | ${'shaMismatch'}
${false} | ${true} | ${'notAllowedToMerge'}
${false} | ${false} | ${'notAllowedToMerge'}
`(
'returns $stateKey when canMerge is $canMerge and isSHAMismatch is $isSHAMismatch',
({ canMerge, isSHAMismatch, stateKey }) => {
const bound = getStateKey.bind(
{
canMerge,
isSHAMismatch,
},
{
commits_count: 2,
},
);
expect(bound()).toEqual(stateKey);
},
);
}); });
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