summaryrefslogtreecommitdiff
path: root/db/post_migrate/20180424151928_fill_file_store.rb.rb
blob: ecf169a495333c25390c57b17247043642ec8170 (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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
class FillFileStore < ActiveRecord::Migration
  include Gitlab::Database::MigrationHelpers

  DOWNTIME = false

  disable_ddl_transaction!

  class Build < ActiveRecord::Base
    include EachBatch
    self.table_name = 'ci_builds'
    BATCH_SIZE = 10_000

    def self.queue_background_migration
      self.class.where(artifacts_file_store: nil).tap do |relation|
        queue_background_migration_jobs_by_range_at_intervals(relation,
          'FillFileStoreBuildArchive',
          5.minutes,
          batch_size: BATCH_SIZE)
      end

      self.class.where(artifacts_metadata_store: nil).tap do |relation|
        queue_background_migration_jobs_by_range_at_intervals(relation,
          'FillFileStoreBuildMetadata',
          5.minutes,
          batch_size: BATCH_SIZE)
      end
    end
  end

  class JobArtifact < ActiveRecord::Base
    include EachBatch
    self.table_name = 'ci_job_artifacts'
    BATCH_SIZE = 10_000

    def self.queue_background_migration
      self.class.where(file_store: nil).tap do |relation|
        queue_background_migration_jobs_by_range_at_intervals(relation,
          'FillFileStoreJobArtifact',
          5.minutes,
          batch_size: BATCH_SIZE)
      end
    end
  end

  class LfsObject < ActiveRecord::Base
    include EachBatch
    self.table_name = 'lfs_objects'
    BATCH_SIZE = 10_000

    def self.queue_background_migration
      self.class.where(file_store: nil).tap do |relation|
        queue_background_migration_jobs_by_range_at_intervals(relation,
          'FillFileStoreLfsObject',
          5.minutes,
          batch_size: BATCH_SIZE)
      end
    end
  end

  class Upload < ActiveRecord::Base
    include EachBatch
    self.table_name = 'uploads'
    BATCH_SIZE = 10_000

    def self.queue_background_migration
      self.class.where(store: nil).tap do |relation|
        queue_background_migration_jobs_by_range_at_intervals(relation,
          'FillFileStoreUpload',
          5.minutes,
          batch_size: BATCH_SIZE)
      end
    end
  end

  def up
    disable_statement_timeout

    # Schedule background migrations that fill 'NULL' value by '1' on `file_store`, `store`, `artifacts_file_store` columns
    # '1' represents ObjectStorage::Store::LOCAL
    # ci_builds.artifacts_file_store
    # ci_builds.artifacts_metadata_store
    # ci_job_artifacts.file_store
    # lfs_objects.file_store
    # uploads.store

    FillFileStore::Build.queue_background_migration
    FillFileStore::JobArtifact.queue_background_migration
    FillFileStore::LfsObject.queue_background_migration
    FillFileStore::Upload.queue_background_migration
  end

  def down
    # noop
  end
end