diff options
author | James Lopez <james@jameslopez.es> | 2017-05-04 12:13:33 +0200 |
---|---|---|
committer | James Lopez <james@jameslopez.es> | 2017-05-04 12:13:33 +0200 |
commit | f81cf84035213002ce7931af6c3ffa917fe7fcbd (patch) | |
tree | 3393496e46cdacd5db03a2348dda8ed1a58a3d57 /app/workers | |
parent | 2f7f1ce4e66db847414e2fc3de09556e75c51eb4 (diff) | |
download | gitlab-ce-f81cf84035213002ce7931af6c3ffa917fe7fcbd.tar.gz |
refactor worker into service
Diffstat (limited to 'app/workers')
-rw-r--r-- | app/workers/propagate_project_service_worker.rb | 34 |
1 files changed, 4 insertions, 30 deletions
diff --git a/app/workers/propagate_project_service_worker.rb b/app/workers/propagate_project_service_worker.rb index 53551770968..ab2b7738f9a 100644 --- a/app/workers/propagate_project_service_worker.rb +++ b/app/workers/propagate_project_service_worker.rb @@ -3,44 +3,18 @@ class PropagateProjectServiceWorker include Sidekiq::Worker include DedicatedSidekiqQueue + sidekiq_options retry: 3 + LEASE_TIMEOUT = 30.minutes.to_i def perform(template_id) - template = Service.find_by(id: template_id) - - return unless template&.active - return unless try_obtain_lease_for(template.id) - - Rails.logger.info("Propagating services for template #{template.id}") + return unless try_obtain_lease_for(template_id) - project_ids_for_template(template) do |project_id| - Service.build_from_template(project_id, template).save! - end + Projects::PropagateService.propagate!(Service.find_by(id: template_id)) end private - def project_ids_for_template(template) - limit = 100 - offset = 0 - - loop do - batch = project_ids_batch(limit, offset, template.type) - - batch.each { |project_id| yield(project_id) } - - break if batch.count < limit - - offset += limit - end - end - - def project_ids_batch(limit, offset, template_type) - Project.joins('LEFT JOIN services ON services.project_id = projects.id'). - where('services.type != ? OR services.id IS NULL', template_type). - limit(limit).offset(offset).pluck(:id) - end - def try_obtain_lease_for(template_id) Gitlab::ExclusiveLease. new("propagate_project_service_worker:#{template_id}", timeout: LEASE_TIMEOUT). |