diff options
author | Matija Čupić <matteeyah@gmail.com> | 2018-09-19 18:54:54 +0200 |
---|---|---|
committer | Matija Čupić <matteeyah@gmail.com> | 2018-09-25 21:09:14 +0200 |
commit | a6ffefc73f65e0662a976b713785e0134b64cbb1 (patch) | |
tree | dfffcf183af49692292084fca1867619fd69e3b8 /db | |
parent | c2fbd8677c27b28d68efab3bfd097a246e083b98 (diff) | |
download | gitlab-ce-a6ffefc73f65e0662a976b713785e0134b64cbb1.tar.gz |
Schedule background migration
Diffstat (limited to 'db')
-rw-r--r-- | db/post_migrate/20180916014356_populate_external_pipeline_source.rb | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/db/post_migrate/20180916014356_populate_external_pipeline_source.rb b/db/post_migrate/20180916014356_populate_external_pipeline_source.rb new file mode 100644 index 00000000000..5577d05cf40 --- /dev/null +++ b/db/post_migrate/20180916014356_populate_external_pipeline_source.rb @@ -0,0 +1,33 @@ +# frozen_string_literal: true + +# See http://doc.gitlab.com/ce/development/migration_style_guide.html +# for more information on how to write migrations for GitLab. + +class PopulateExternalPipelineSource < ActiveRecord::Migration + include Gitlab::Database::MigrationHelpers + + # Set this constant to true if this migration requires downtime. + DOWNTIME = false + MIGRATION = 'PopulateExternalPipelineSource'.freeze + BATCH_SIZE = 500 + + disable_ddl_transaction! + + class Pipeline < ActiveRecord::Base + include EachBatch + self.table_name = 'ci_pipelines' + end + + def up + Pipeline.where(source: nil).tap do |relation| + queue_background_migration_jobs_by_range_at_intervals(relation, + MIGRATION, + 5.minutes, + batch_size: BATCH_SIZE) + end + end + + def down + # noop + end +end |