summaryrefslogtreecommitdiff
path: root/lib/gitlab/background_migration/backfill_artifact_expiry_date.rb
blob: f6b36571c90f7cd45d51ec4b5d73293570320ce4 (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
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
# frozen_string_literal: true

module Gitlab
  module BackgroundMigration
    # Backfill expire_at for a range of Ci::JobArtifact
    class BackfillArtifactExpiryDate
      include Gitlab::Utils::StrongMemoize

      SWITCH_DATE = Date.new(2020, 06, 22).freeze
      OLD_ARTIFACT_AGE = 15.months
      BATCH_SIZE = 1_000
      OLD_ARTIFACT_EXPIRY_OFFSET = 3.months
      RECENT_ARTIFACT_EXPIRY_OFFSET = 1.year

      # Ci::JobArtifact model
      class Ci::JobArtifact < ActiveRecord::Base
        include ::EachBatch

        self.table_name = 'ci_job_artifacts'

        scope :without_expiry_date, -> { where(expire_at: nil) }
        scope :before_switch, -> { where("date(created_at AT TIME ZONE 'UTC') < ?::date", SWITCH_DATE) }
        scope :between, -> (start_id, end_id) { where(id: start_id..end_id) }
        scope :old, -> { where(self.arel_table[:created_at].lt(OLD_ARTIFACT_AGE.ago)) }
        scope :recent, -> { where(self.arel_table[:created_at].gt(OLD_ARTIFACT_AGE.ago)) }
      end

      def perform(start_id, end_id)
        Ci::JobArtifact
          .without_expiry_date.before_switch
          .between(start_id, end_id)
          .each_batch(of: BATCH_SIZE) do |batch|
          batch.old.update_all(expire_at: old_artifact_expiry_date)
          batch.recent.update_all(expire_at: recent_artifact_expiry_date)
        end
      end

      private

      def offset_date
        strong_memoize(:offset_date) do
          current_date = Time.current
          target_date = Time.zone.local(current_date.year, current_date.month, 22, 0, 0, 0)

          current_date.day < 22 ? target_date : target_date.next_month
        end
      end

      def old_artifact_expiry_date
        offset_date + OLD_ARTIFACT_EXPIRY_OFFSET
      end

      def recent_artifact_expiry_date
        offset_date + RECENT_ARTIFACT_EXPIRY_OFFSET
      end
    end
  end
end