debian-mirror-gitlab/app/workers/merge_request_cleanup_refs_worker.rb

72 lines
1.7 KiB
Ruby
Raw Normal View History

2020-11-24 15:15:51 +05:30
# frozen_string_literal: true
class MergeRequestCleanupRefsWorker
include ApplicationWorker
2021-09-30 23:02:18 +05:30
include LimitedCapacity::Worker
include Gitlab::Utils::StrongMemoize
2020-11-24 15:15:51 +05:30
2021-10-27 15:23:28 +05:30
data_consistency :always
2021-06-08 01:23:25 +05:30
sidekiq_options retry: 3
2021-02-22 17:27:13 +05:30
feature_category :code_review
2020-11-24 15:15:51 +05:30
idempotent!
2021-09-30 23:02:18 +05:30
# Hard-coded to 4 for now. Will be configurable later on via application settings.
# This means, there can only be 4 jobs running at the same time at maximum.
MAX_RUNNING_JOBS = 4
FAILURE_THRESHOLD = 3
2021-03-11 19:13:27 +05:30
2021-09-30 23:02:18 +05:30
def perform_work
return unless Feature.enabled?(:merge_request_refs_cleanup, default_enabled: false)
2020-11-24 15:15:51 +05:30
unless merge_request
2021-09-30 23:02:18 +05:30
logger.error('No existing merge request to be cleaned up.')
2020-11-24 15:15:51 +05:30
return
end
2021-09-30 23:02:18 +05:30
log_extra_metadata_on_done(:merge_request_id, merge_request.id)
result = MergeRequests::CleanupRefsService.new(merge_request).execute
if result[:status] == :success
merge_request_cleanup_schedule.complete!
else
if merge_request_cleanup_schedule.failed_count < FAILURE_THRESHOLD
merge_request_cleanup_schedule.retry!
else
merge_request_cleanup_schedule.mark_as_failed!
end
log_extra_metadata_on_done(:message, result[:message])
end
log_extra_metadata_on_done(:status, merge_request_cleanup_schedule.status)
end
def remaining_work_count
MergeRequest::CleanupSchedule
.scheduled_and_unstarted
.limit(max_running_jobs)
.count
end
def max_running_jobs
MAX_RUNNING_JOBS
end
private
2020-11-24 15:15:51 +05:30
2021-09-30 23:02:18 +05:30
def merge_request
strong_memoize(:merge_request) do
merge_request_cleanup_schedule&.merge_request
end
end
2020-11-24 15:15:51 +05:30
2021-09-30 23:02:18 +05:30
def merge_request_cleanup_schedule
strong_memoize(:merge_request_cleanup_schedule) do
MergeRequest::CleanupSchedule.start_next
end
2020-11-24 15:15:51 +05:30
end
end