Welcome to mirror list, hosted at ThFree Co, Russian Federation.

unlock_artifacts_service.rb « ci « services « app - gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 07faf90dd6db3401b154c790801a4cbc5aa145d1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
# frozen_string_literal: true

module Ci
  class UnlockArtifactsService < ::BaseService
    BATCH_SIZE = 100

    def execute(ci_ref, before_pipeline = nil)
      query = <<~SQL.squish
        UPDATE "ci_pipelines"
        SET    "locked" = #{::Ci::Pipeline.lockeds[:unlocked]}
        WHERE  "ci_pipelines"."id" in (
            #{collect_pipelines(ci_ref, before_pipeline).select(:id).to_sql}
            LIMIT  #{BATCH_SIZE}
            FOR  UPDATE SKIP LOCKED
        )
        RETURNING "ci_pipelines"."id";
      SQL

      loop do
        break if ActiveRecord::Base.connection.exec_query(query).empty?
      end
    end

    private

    def collect_pipelines(ci_ref, before_pipeline)
      pipeline_scope = ci_ref.pipelines
      pipeline_scope = pipeline_scope.before_pipeline(before_pipeline) if before_pipeline

      pipeline_scope.artifacts_locked
    end
  end
end