Class: Ci::PipelineProcessing::AtomicProcessingService

Inherits:
Object
  • Object
show all
Includes:
ExclusiveLeaseGuard, Gitlab::Utils::StrongMemoize
Defined in:
app/services/ci/pipeline_processing/atomic_processing_service.rb,
app/services/ci/pipeline_processing/atomic_processing_service/status_collection.rb

Defined Under Namespace

Classes: StatusCollection

Constant Summary collapse

DEFAULT_LEASE_TIMEOUT =
1.minute
BATCH_SIZE =
20

Instance Attribute Summary collapse

Instance Method Summary collapse

Methods included from ExclusiveLeaseGuard

#exclusive_lease, #lease_release?, #log_error, #release_lease, #renew_lease!, #try_obtain_lease

Methods included from Gitlab::Utils::StrongMemoize

#clear_memoization, #strong_memoize, #strong_memoized?

Constructor Details

#initialize(pipeline) ⇒ AtomicProcessingService

Returns a new instance of AtomicProcessingService.


14
15
16
17
# File 'app/services/ci/pipeline_processing/atomic_processing_service.rb', line 14

def initialize(pipeline)
  @pipeline = pipeline
  @collection = AtomicProcessingService::StatusCollection.new(pipeline)
end

Instance Attribute Details

#pipelineObject (readonly)

Returns the value of attribute pipeline


9
10
11
# File 'app/services/ci/pipeline_processing/atomic_processing_service.rb', line 9

def pipeline
  @pipeline
end

Instance Method Details

#executeObject


19
20
21
22
23
24
25
26
27
28
29
30
# File 'app/services/ci/pipeline_processing/atomic_processing_service.rb', line 19

def execute
  return unless pipeline.needs_processing?

  success = try_obtain_lease { process! }

  # re-schedule if we need further processing
  if success && pipeline.needs_processing?
    PipelineProcessWorker.perform_async(pipeline.id)
  end

  success
end