Class: Projects::DeleteBranchWorker
- Inherits:
-
Object
- Object
- Projects::DeleteBranchWorker
- Includes:
- ApplicationWorker
- Defined in:
- app/workers/projects/delete_branch_worker.rb
Constant Summary collapse
- GitReferenceLockedError =
Temporary error when Gitaly cannot lock the branch reference. A retry should solve it.
Class.new(::Gitlab::SidekiqMiddleware::RetryError)
Constants included from ApplicationWorker
ApplicationWorker::LOGGING_EXTRA_KEY, ApplicationWorker::SAFE_PUSH_BULK_LIMIT
Constants included from Gitlab::Loggable
Constants included from WorkerAttributes
WorkerAttributes::DEFAULT_DATA_CONSISTENCY, WorkerAttributes::DEFAULT_DATA_CONSISTENCY_PER_DB, WorkerAttributes::DEFAULT_DEFER_DELAY, WorkerAttributes::LOAD_BALANCED_DATA_CONSISTENCIES, WorkerAttributes::NAMESPACE_WEIGHTS, WorkerAttributes::VALID_DATA_CONSISTENCIES, WorkerAttributes::VALID_RESOURCE_BOUNDARIES, WorkerAttributes::VALID_URGENCIES
Instance Method Summary collapse
Methods included from Gitlab::Loggable
Methods included from Gitlab::SidekiqVersioning::Worker
Methods included from WorkerContext
Instance Method Details
#perform(project_id, user_id, branch_name) ⇒ Object
16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 |
# File 'app/workers/projects/delete_branch_worker.rb', line 16 def perform(project_id, user_id, branch_name) project = Project.find_by_id(project_id) user = User.find_by_id(user_id) return unless project.present? && user.present? return unless project.repository.branch_exists?(branch_name) delete_service_result = ::Branches::DeleteService.new(project, user) .execute(branch_name) # Only want to raise on 400 to avoid permission and non existant branch error return unless delete_service_result[:http_status] == 400 delete_service_result.log_and_raise_exception(as: GitReferenceLockedError) end |