summaryrefslogtreecommitdiff
path: root/app/services/merge_requests/squash_service.rb
diff options
context:
space:
mode:
authorGitLab Bot <gitlab-bot@gitlab.com>2020-07-17 21:09:23 +0000
committerGitLab Bot <gitlab-bot@gitlab.com>2020-07-17 21:09:23 +0000
commit1d84a028b42a1a3aed36a0f3a6cae970c8df8e69 (patch)
tree1ebd0249d20169a0b8be47dc541e9c2676d62648 /app/services/merge_requests/squash_service.rb
parentec72da1833d94bb1556af94193ccf2a93c9cb939 (diff)
downloadgitlab-ce-1d84a028b42a1a3aed36a0f3a6cae970c8df8e69.tar.gz
Add latest changes from gitlab-org/gitlab@master
Diffstat (limited to 'app/services/merge_requests/squash_service.rb')
-rw-r--r--app/services/merge_requests/squash_service.rb10
1 files changed, 7 insertions, 3 deletions
diff --git a/app/services/merge_requests/squash_service.rb b/app/services/merge_requests/squash_service.rb
index faa2e921581..94ce7098d3a 100644
--- a/app/services/merge_requests/squash_service.rb
+++ b/app/services/merge_requests/squash_service.rb
@@ -7,9 +7,7 @@ module MergeRequests
def execute
# If performing a squash would result in no change, then
# immediately return a success message without performing a squash
- if merge_request.commits_count < 2 && message.nil?
- return success(squash_sha: merge_request.diff_head_sha)
- end
+ return success(squash_sha: merge_request.diff_head_sha) if squash_redundant?
return error(s_('MergeRequests|This project does not allow squashing commits when merge requests are accepted.')) if squash_forbidden?
@@ -25,6 +23,12 @@ module MergeRequests
private
+ def squash_redundant?
+ return true if merge_request.merged?
+
+ merge_request.commits_count < 2 && message.nil?
+ end
+
def squash!
squash_sha = repository.squash(current_user, merge_request, message || merge_request.default_squash_commit_message)