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

20170526185842_migrate_pipeline_stages.rb « post_migrate « db - gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: afd4db183c2edcb4e3fd721fbb036040db9c5c07 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
class MigratePipelineStages < ActiveRecord::Migration
  include Gitlab::Database::MigrationHelpers

  DOWNTIME = false

  disable_ddl_transaction!

  def up
    disable_statement_timeout

    execute <<-SQL.strip_heredoc
      INSERT INTO ci_stages (project_id, pipeline_id, name)
        SELECT project_id, commit_id, stage FROM ci_builds
          WHERE stage IS NOT NULL
          AND stage_id IS NULL
          AND EXISTS (SELECT 1 FROM projects WHERE projects.id = ci_builds.project_id)
          AND EXISTS (SELECT 1 FROM ci_pipelines WHERE ci_pipelines.id = ci_builds.commit_id)
          GROUP BY project_id, commit_id, stage
          ORDER BY MAX(stage_idx)
    SQL
  end
end