debian-mirror-gitlab/app/services/merge_requests/squash_service.rb

56 lines
1.5 KiB
Ruby
Raw Normal View History

2018-11-18 11:00:15 +05:30
# frozen_string_literal: true
2018-11-08 19:23:39 +05:30
module MergeRequests
2019-12-26 22:10:19 +05:30
class SquashService < MergeRequests::BaseService
2020-05-24 23:13:21 +05:30
SquashInProgressError = Class.new(RuntimeError)
2019-12-26 22:10:19 +05:30
2019-03-02 22:35:43 +05:30
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?
2018-11-08 19:23:39 +05:30
return success(squash_sha: merge_request.diff_head_sha)
end
2020-05-24 23:13:21 +05:30
if squash_in_progress?
2019-07-31 22:56:46 +05:30
return error(s_('MergeRequests|Squash task canceled: another squash is already in progress.'))
2018-11-08 19:23:39 +05:30
end
2019-07-31 22:56:46 +05:30
squash! || error(s_('MergeRequests|Failed to squash. Should be done manually.'))
2020-05-24 23:13:21 +05:30
rescue SquashInProgressError
error(s_('MergeRequests|An error occurred while checking whether another squash is in progress.'))
2019-03-02 22:35:43 +05:30
end
private
def squash!
squash_sha = repository.squash(current_user, merge_request, message || merge_request.default_squash_commit_message)
2018-11-08 19:23:39 +05:30
success(squash_sha: squash_sha)
rescue => e
2020-05-24 23:13:21 +05:30
log_error(exception: e, message: 'Failed to squash merge request')
2018-11-08 19:23:39 +05:30
false
end
2019-03-02 22:35:43 +05:30
2020-05-24 23:13:21 +05:30
def squash_in_progress?
merge_request.squash_in_progress?
rescue => e
log_error(exception: e, message: 'Failed to check squash in progress')
raise SquashInProgressError, e.message
end
2019-03-02 22:35:43 +05:30
def repository
target_project.repository
end
def merge_request
params[:merge_request]
end
def message
params[:squash_commit_message].presence
end
2018-11-08 19:23:39 +05:30
end
end