2018-03-17 18:26:18 +05:30
|
|
|
# rubocop:disable Migration/UpdateLargeTable
|
2019-01-03 12:48:30 +05:30
|
|
|
class AddHeadPipelineForEachMergeRequest < ActiveRecord::Migration
|
2017-09-10 17:25:29 +05:30
|
|
|
include Gitlab::Database::MigrationHelpers
|
|
|
|
|
|
|
|
DOWNTIME = false
|
|
|
|
|
|
|
|
disable_ddl_transaction!
|
|
|
|
|
|
|
|
def up
|
|
|
|
pipelines = Arel::Table.new(:ci_pipelines)
|
|
|
|
merge_requests = Arel::Table.new(:merge_requests)
|
|
|
|
|
2018-11-20 20:47:30 +05:30
|
|
|
disable_statement_timeout do
|
|
|
|
head_id = pipelines
|
|
|
|
.project(Arel::Nodes::NamedFunction.new('max', [pipelines[:id]]))
|
|
|
|
.from(pipelines)
|
|
|
|
.where(pipelines[:ref].eq(merge_requests[:source_branch]))
|
|
|
|
.where(pipelines[:project_id].eq(merge_requests[:source_project_id]))
|
2017-09-10 17:25:29 +05:30
|
|
|
|
2018-11-20 20:47:30 +05:30
|
|
|
sub_query = Arel::Nodes::SqlLiteral.new(Arel::Nodes::Grouping.new(head_id).to_sql)
|
2017-09-10 17:25:29 +05:30
|
|
|
|
2018-11-20 20:47:30 +05:30
|
|
|
update_column_in_batches(:merge_requests, :head_pipeline_id, sub_query)
|
|
|
|
end
|
2017-09-10 17:25:29 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
def down
|
|
|
|
end
|
|
|
|
end
|