summaryrefslogtreecommitdiff
path: root/db/migrate/20200701064756_add_not_valid_foreign_key_to_cycle_analytics_group_stages.rb
blob: e54cecc5af8daa815edc9821a49f94dcbf14e560 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
# frozen_string_literal: true

class AddNotValidForeignKeyToCycleAnalyticsGroupStages < ActiveRecord::Migration[6.0]
  include Gitlab::Database::MigrationHelpers

  DOWNTIME = false
  CONSTRAINT_NAME = 'fk_analytics_cycle_analytics_group_stages_group_value_stream_id'
  INDEX_NAME = 'index_analytics_ca_group_stages_on_value_stream_id'

  disable_ddl_transaction!

  def up
    add_concurrent_index :analytics_cycle_analytics_group_stages, :group_value_stream_id, name: INDEX_NAME
    add_foreign_key :analytics_cycle_analytics_group_stages, :analytics_cycle_analytics_group_value_streams,
      column: :group_value_stream_id, name: CONSTRAINT_NAME, on_delete: :cascade, validate: false
  end

  def down
    remove_foreign_key_if_exists :analytics_cycle_analytics_group_stages, column: :group_value_stream_id, name: CONSTRAINT_NAME
    remove_concurrent_index :analytics_cycle_analytics_group_stages, :group_value_stream_id
  end
end