Class: MergeRequests::CleanupRefWorker

Inherits:
Object
  • Object
show all
Includes:
ApplicationWorker, Projects::RemoveRefs
Defined in:
app/workers/merge_requests/cleanup_ref_worker.rb

Constant Summary

Constants included from Projects::RemoveRefs

Projects::RemoveRefs::LOCK_RETRY, Projects::RemoveRefs::LOCK_SLEEP, Projects::RemoveRefs::LOCK_TTL

Constants included from Gitlab::ExclusiveLeaseHelpers

Gitlab::ExclusiveLeaseHelpers::FailedToObtainLockError

Constants included from ApplicationWorker

ApplicationWorker::LOGGING_EXTRA_KEY, ApplicationWorker::SAFE_PUSH_BULK_LIMIT

Constants included from Gitlab::Loggable

Gitlab::Loggable::ANONYMOUS

Constants included from WorkerAttributes

WorkerAttributes::DEFAULT_DATA_CONSISTENCY, WorkerAttributes::DEFAULT_DEFER_DELAY, WorkerAttributes::NAMESPACE_WEIGHTS, WorkerAttributes::VALID_DATA_CONSISTENCIES, WorkerAttributes::VALID_RESOURCE_BOUNDARIES, WorkerAttributes::VALID_URGENCIES

Instance Method Summary collapse

Methods included from Projects::RemoveRefs

#lock_params, #serialized_remove_refs

Methods included from Gitlab::ExclusiveLeaseHelpers

#in_lock

Methods included from Gitlab::Loggable

#build_structured_payload

Methods included from Gitlab::SidekiqVersioning::Worker

#job_version

Methods included from WorkerContext

#with_context

Instance Method Details

#perform(merge_request_id, only) ⇒ Object

Even though this worker is de-duplicated we need to acquire lock on a project to avoid running many concurrent refs removals

TODO: Once underlying fix is done we can remove ‘in_lock`

Related to:



26
27
28
29
30
31
32
33
# File 'app/workers/merge_requests/cleanup_ref_worker.rb', line 26

def perform(merge_request_id, only)
  merge_request = MergeRequest.find_by_id(merge_request_id)
  return unless merge_request

  serialized_remove_refs(merge_request.target_project_id) do
    merge_request.cleanup_refs(only: only.to_sym)
  end
end