summaryrefslogtreecommitdiff
path: root/db/migrate/20190830140240_add_duplicated_to_to_issue.rb
blob: b38e4302a0b488da7e0b49512e138f28eb9d0763 (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
# frozen_string_literal: true

class AddDuplicatedToToIssue < ActiveRecord::Migration[5.2]
  include Gitlab::Database::MigrationHelpers

  DOWNTIME = false

  disable_ddl_transaction!

  def up
    add_column :issues, :duplicated_to_id, :integer unless duplicated_to_id_exists?
    add_concurrent_foreign_key :issues, :issues, column: :duplicated_to_id, on_delete: :nullify
    add_concurrent_index :issues, :duplicated_to_id, where: 'duplicated_to_id IS NOT NULL'
  end

  def down
    remove_foreign_key_without_error(:issues, column: :duplicated_to_id)
    remove_concurrent_index(:issues, :duplicated_to_id)
    remove_column(:issues, :duplicated_to_id) if duplicated_to_id_exists?
  end

  private

  def duplicated_to_id_exists?
    column_exists?(:issues, :duplicated_to_id)
  end
end