2018-07-17 12:50:37 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2017-12-20 04:01:21 -05:00
|
|
|
module MergeRequests
|
2019-11-15 13:06:24 -05:00
|
|
|
class RebaseService < MergeRequests::BaseService
|
2022-02-07 10:15:53 -05:00
|
|
|
REBASE_ERROR = 'Rebase failed: Rebase locally, resolve all conflicts, then push the branch.'
|
2018-01-09 10:49:39 -05:00
|
|
|
|
2021-12-01 04:10:25 -05:00
|
|
|
attr_reader :merge_request, :rebase_error
|
2019-11-15 13:06:24 -05:00
|
|
|
|
2020-01-16 16:08:24 -05:00
|
|
|
def execute(merge_request, skip_ci: false)
|
2017-12-20 04:01:21 -05:00
|
|
|
@merge_request = merge_request
|
2020-01-16 16:08:24 -05:00
|
|
|
@skip_ci = skip_ci
|
2017-12-20 04:01:21 -05:00
|
|
|
|
|
|
|
if rebase
|
|
|
|
success
|
|
|
|
else
|
2021-12-01 04:10:25 -05:00
|
|
|
error(rebase_error)
|
2017-12-20 04:01:21 -05:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def rebase
|
2020-01-16 16:08:24 -05:00
|
|
|
repository.rebase(current_user, merge_request, skip_ci: @skip_ci)
|
2018-06-27 05:47:30 -04:00
|
|
|
|
2017-12-20 04:01:21 -05:00
|
|
|
true
|
2021-04-26 08:09:44 -04:00
|
|
|
rescue StandardError => e
|
2021-12-01 04:10:25 -05:00
|
|
|
set_rebase_error(e)
|
|
|
|
log_error(exception: e, message: rebase_error, save_message_on_model: true)
|
2020-05-07 11:09:29 -04:00
|
|
|
|
2017-12-20 04:01:21 -05:00
|
|
|
false
|
2019-06-21 12:56:47 -04:00
|
|
|
ensure
|
|
|
|
merge_request.update_column(:rebase_jid, nil)
|
2017-12-20 04:01:21 -05:00
|
|
|
end
|
2021-12-01 04:10:25 -05:00
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def set_rebase_error(exception)
|
|
|
|
@rebase_error =
|
|
|
|
if exception.is_a?(Gitlab::Git::PreReceiveError)
|
2022-02-07 10:15:53 -05:00
|
|
|
"The rebase pre-receive hook failed: #{exception.message}."
|
2021-12-01 04:10:25 -05:00
|
|
|
else
|
|
|
|
REBASE_ERROR
|
|
|
|
end
|
|
|
|
end
|
2017-12-20 04:01:21 -05:00
|
|
|
end
|
|
|
|
end
|