2018-02-19 14:06:16 -05:00
|
|
|
class AddGroupIdToBoards < ActiveRecord::Migration
|
|
|
|
include Gitlab::Database::MigrationHelpers
|
|
|
|
|
|
|
|
disable_ddl_transaction!
|
|
|
|
|
|
|
|
DOWNTIME = false
|
|
|
|
|
|
|
|
def up
|
2018-03-05 09:39:24 -05:00
|
|
|
return if group_id_exists?
|
|
|
|
|
|
|
|
add_column :boards, :group_id, :integer
|
|
|
|
add_foreign_key :boards, :namespaces, column: :group_id, on_delete: :cascade
|
|
|
|
add_concurrent_index :boards, :group_id
|
2018-02-19 14:06:16 -05:00
|
|
|
|
2018-03-05 09:39:24 -05:00
|
|
|
change_column_null :boards, :project_id, true
|
2018-02-19 14:06:16 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
def down
|
2018-03-05 09:39:24 -05:00
|
|
|
return unless group_id_exists?
|
|
|
|
|
|
|
|
remove_foreign_key :boards, column: :group_id
|
|
|
|
remove_index :boards, :group_id if index_exists? :boards, :group_id
|
|
|
|
remove_column :boards, :group_id
|
|
|
|
|
|
|
|
execute "DELETE from boards WHERE project_id IS NULL"
|
|
|
|
change_column_null :boards, :project_id, false
|
2018-02-19 14:06:16 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def group_id_exists?
|
|
|
|
column_exists?(:boards, :group_id)
|
|
|
|
end
|
|
|
|
end
|