summaryrefslogtreecommitdiff
path: root/db/post_migrate/20221226153240_remove_chat_names_integration_id_foreign_key.rb
blob: 51baa9c9f5721fd4c871545155b01df26415dc87 (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 RemoveChatNamesIntegrationIdForeignKey < Gitlab::Database::Migration[2.1]
  disable_ddl_transaction!

  SOURCE_TABLE_NAME = :chat_names
  TARGET_TABLE_NAME = :integrations
  COLUMN = :integration_id
  TARGET_COLUMN = :id
  FK_NAME = :fk_99a1348daf

  def up
    with_lock_retries do
      remove_foreign_key_if_exists(SOURCE_TABLE_NAME, name: FK_NAME)
    end
  end

  def down
    add_concurrent_foreign_key(
      SOURCE_TABLE_NAME,
      TARGET_TABLE_NAME,
      column: COLUMN,
      name: FK_NAME,
      on_delete: :cascade
    )
  end
end