Check foreign keys in migration in separate conditional
This commit is contained in:
parent
6a61528512
commit
5af3eb5f9f
|
@ -8,14 +8,28 @@ class AddStageIdForeignKeyToBuilds < ActiveRecord::Migration
|
|||
def up
|
||||
unless index_exists?(:ci_builds, :stage_id)
|
||||
add_concurrent_index(:ci_builds, :stage_id)
|
||||
end
|
||||
|
||||
unless foreign_key_exists?(:ci_builds, :stage_id)
|
||||
add_concurrent_foreign_key(:ci_builds, :ci_stages, column: :stage_id, on_delete: :cascade)
|
||||
end
|
||||
end
|
||||
|
||||
def down
|
||||
if index_exists?(:ci_builds, :stage_id)
|
||||
if foreign_key_exists?(:ci_builds, :stage_id)
|
||||
remove_foreign_key(:ci_builds, column: :stage_id)
|
||||
end
|
||||
|
||||
if index_exists?(:ci_builds, :stage_id)
|
||||
remove_concurrent_index(:ci_builds, :stage_id)
|
||||
end
|
||||
end
|
||||
|
||||
private
|
||||
|
||||
def foreign_key_exists?(table, column)
|
||||
foreign_keys(:ci_builds).any? do |key|
|
||||
key.options[:column] == column.to_s
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
Loading…
Reference in New Issue