summaryrefslogtreecommitdiff
path: root/app/workers/schedule_merge_request_cleanup_refs_worker.rb
diff options
context:
space:
mode:
Diffstat (limited to 'app/workers/schedule_merge_request_cleanup_refs_worker.rb')
-rw-r--r--app/workers/schedule_merge_request_cleanup_refs_worker.rb26
1 files changed, 26 insertions, 0 deletions
diff --git a/app/workers/schedule_merge_request_cleanup_refs_worker.rb b/app/workers/schedule_merge_request_cleanup_refs_worker.rb
new file mode 100644
index 00000000000..17cabba4278
--- /dev/null
+++ b/app/workers/schedule_merge_request_cleanup_refs_worker.rb
@@ -0,0 +1,26 @@
+# frozen_string_literal: true
+
+class ScheduleMergeRequestCleanupRefsWorker
+ include ApplicationWorker
+ include CronjobQueue # rubocop:disable Scalability/CronWorkerContext
+
+ feature_category :source_code_management
+ idempotent!
+
+ # Based on existing data, MergeRequestCleanupRefsWorker can run 3 jobs per
+ # second. This means that 180 jobs can be performed but since there are some
+ # spikes from time time, it's better to give it some allowance.
+ LIMIT = 180
+ DELAY = 10.seconds
+ BATCH_SIZE = 30
+
+ def perform
+ return if Gitlab::Database.read_only?
+
+ ids = MergeRequest::CleanupSchedule.scheduled_merge_request_ids(LIMIT).map { |id| [id] }
+
+ MergeRequestCleanupRefsWorker.bulk_perform_in(DELAY, ids, batch_size: BATCH_SIZE) # rubocop:disable Scalability/BulkPerformWithContext
+
+ log_extra_metadata_on_done(:merge_requests_count, ids.size)
+ end
+end