Skip to content
代码片段 群组 项目
未验证 提交 46e42e07 编辑于 作者: Sean Arnold's avatar Sean Arnold 提交者: GitLab
浏览文件

Merge branch 'ab-remove-meta-programming-from-merge-strategy-choice' into 'master'

Make AutoMerge name-spaced class instantiation in AutoMergeService searchable

See merge request https://gitlab.com/gitlab-org/gitlab/-/merge_requests/166778



Merged-by: default avatarSean Arnold <sarnold@gitlab.com>
Approved-by: default avatarSean Arnold <sarnold@gitlab.com>
Approved-by: default avatarAvielle Wolfe <awolfe@gitlab.com>
Co-authored-by: default avatarAllison Browne <abrowne@gitlab.com>
No related branches found
No related tags found
无相关合并请求
...@@ -17,13 +17,20 @@ def all_strategies_ordered_by_preference ...@@ -17,13 +17,20 @@ def all_strategies_ordered_by_preference
def get_service_class(strategy) def get_service_class(strategy)
return unless all_strategies_ordered_by_preference.include?(strategy) return unless all_strategies_ordered_by_preference.include?(strategy)
"::AutoMerge::#{strategy.camelize}Service".constantize strategy_to_class_map[strategy]
end
def strategy_to_class_map
{
STRATEGY_MERGE_WHEN_PIPELINE_SUCCEEDS => AutoMerge::MergeWhenPipelineSucceedsService,
STRATEGY_MERGE_WHEN_CHECKS_PASS => AutoMerge::MergeWhenChecksPassService
}
end end
end end
def execute(merge_request, strategy = nil) def execute(merge_request, strategy = nil)
strategy ||= preferred_strategy(merge_request) strategy ||= preferred_strategy(merge_request)
service = get_service_instance(merge_request, strategy) service = auto_merge_service_instance(merge_request, strategy)
return :failed unless service&.available_for?(merge_request) return :failed unless service&.available_for?(merge_request)
...@@ -34,33 +41,33 @@ def update(merge_request) ...@@ -34,33 +41,33 @@ def update(merge_request)
return :failed unless merge_request.auto_merge_enabled? return :failed unless merge_request.auto_merge_enabled?
strategy = merge_request.auto_merge_strategy strategy = merge_request.auto_merge_strategy
get_service_instance(merge_request, strategy).update(merge_request) auto_merge_service_instance(merge_request, strategy).update(merge_request)
end end
def process(merge_request) def process(merge_request)
return unless merge_request.auto_merge_enabled? return unless merge_request.auto_merge_enabled?
strategy = merge_request.auto_merge_strategy strategy = merge_request.auto_merge_strategy
get_service_instance(merge_request, strategy).process(merge_request) auto_merge_service_instance(merge_request, strategy).process(merge_request)
end end
def cancel(merge_request) def cancel(merge_request)
return error("Can't cancel the automatic merge", 406) unless merge_request.auto_merge_enabled? return error("Can't cancel the automatic merge", 406) unless merge_request.auto_merge_enabled?
strategy = merge_request.auto_merge_strategy strategy = merge_request.auto_merge_strategy
get_service_instance(merge_request, strategy).cancel(merge_request) auto_merge_service_instance(merge_request, strategy).cancel(merge_request)
end end
def abort(merge_request, reason) def abort(merge_request, reason)
return error("Can't abort the automatic merge", 406) unless merge_request.auto_merge_enabled? return error("Can't abort the automatic merge", 406) unless merge_request.auto_merge_enabled?
strategy = merge_request.auto_merge_strategy strategy = merge_request.auto_merge_strategy
get_service_instance(merge_request, strategy).abort(merge_request, reason) auto_merge_service_instance(merge_request, strategy).abort(merge_request, reason)
end end
def available_strategies(merge_request) def available_strategies(merge_request)
self.class.all_strategies_ordered_by_preference.select do |strategy| self.class.all_strategies_ordered_by_preference.select do |strategy|
get_service_instance(merge_request, strategy).available_for?(merge_request) auto_merge_service_instance(merge_request, strategy).available_for?(merge_request)
end end
end end
...@@ -70,8 +77,8 @@ def preferred_strategy(merge_request) ...@@ -70,8 +77,8 @@ def preferred_strategy(merge_request)
private private
def get_service_instance(merge_request, strategy) def auto_merge_service_instance(merge_request, strategy)
strong_memoize("service_instance_#{merge_request.id}_#{strategy}") do strong_memoize_with(:auto_merge_service_instance, merge_request, strategy) do
self.class.get_service_class(strategy)&.new(project, current_user, params) self.class.get_service_class(strategy)&.new(project, current_user, params)
end end
end end
......
# frozen_string_literal: true # frozen_string_literal: true
#
# Note: This service is called via metaprogramming in AutoMergeService
# which is triggered by the AutoMergeProcessWorker when a pipeline completes
#
module AutoMerge module AutoMerge
class MergeTrainService < AutoMerge::BaseService class MergeTrainService < AutoMerge::BaseService
extend Gitlab::Utils::Override extend Gitlab::Utils::Override
......
...@@ -13,6 +13,13 @@ module AutoMergeService ...@@ -13,6 +13,13 @@ module AutoMergeService
::AutoMergeService::STRATEGY_ADD_TO_MERGE_TRAIN_WHEN_CHECKS_PASS ::AutoMergeService::STRATEGY_ADD_TO_MERGE_TRAIN_WHEN_CHECKS_PASS
].freeze ].freeze
EE_STRATEGY_TO_CLASS_MAP = {
STRATEGY_MERGE_TRAIN => AutoMerge::MergeTrainService,
STRATEGY_ADD_TO_MERGE_TRAIN_WHEN_PIPELINE_SUCCEEDS => AutoMerge::AddToMergeTrainWhenPipelineSucceedsService,
::AutoMergeService::STRATEGY_ADD_TO_MERGE_TRAIN_WHEN_CHECKS_PASS =>
AutoMerge::AddToMergeTrainWhenChecksPassService
}.freeze
class_methods do class_methods do
extend ::Gitlab::Utils::Override extend ::Gitlab::Utils::Override
include ::Gitlab::Utils::StrongMemoize include ::Gitlab::Utils::StrongMemoize
...@@ -23,6 +30,12 @@ def all_strategies_ordered_by_preference ...@@ -23,6 +30,12 @@ def all_strategies_ordered_by_preference
EE_STRATEGIES + super EE_STRATEGIES + super
end end
end end
private
def strategy_to_class_map
super.merge(EE_STRATEGY_TO_CLASS_MAP)
end
end end
end end
end end
0% 加载中 .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册