gitlab-org--gitlab-foss/app/services/merge_requests/squash_service.rb

56 lines
1.5 KiB
Ruby
Raw Normal View History

# frozen_string_literal: true
2018-05-29 09:51:43 +00:00
module MergeRequests
class SquashService < MergeRequests::BaseService
SquashInProgressError = Class.new(RuntimeError)
2019-02-06 12:33:11 +00:00
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
2018-05-29 09:51:43 +00:00
if squash_in_progress?
return error(s_('MergeRequests|Squash task canceled: another squash is already in progress.'))
2018-05-29 09:51:43 +00:00
end
squash! || error(s_('MergeRequests|Failed to squash. Should be done manually.'))
rescue SquashInProgressError
error(s_('MergeRequests|An error occurred while checking whether another squash is in progress.'))
2019-02-06 12:33:11 +00:00
end
private
def squash!
squash_sha = repository.squash(current_user, merge_request, message || merge_request.default_squash_commit_message)
2018-05-29 09:51:43 +00:00
success(squash_sha: squash_sha)
rescue => e
log_error(exception: e, message: 'Failed to squash merge request')
2018-05-29 09:51:43 +00:00
false
end
2019-02-06 12:33:11 +00:00
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-02-06 12:33:11 +00:00
def repository
target_project.repository
end
def merge_request
params[:merge_request]
end
def message
params[:squash_commit_message].presence
end
2018-05-29 09:51:43 +00:00
end
end