diff options
author | Andreas Brandl <abrandl@gitlab.com> | 2019-09-09 12:48:48 +0000 |
---|---|---|
committer | Andreas Brandl <abrandl@gitlab.com> | 2019-09-09 12:48:48 +0000 |
commit | 5abc37bd85ca3ab28f7fb6fdbb6db8161f51d8fb (patch) | |
tree | ac9e26ba745c7ade7711b5026c70d77ff3d5cd0e /db | |
parent | b5343bba31687dabdb7ede19cab453c3294b162c (diff) | |
parent | d1c761b3e93ec09ba3f77ba7f4b2f229c425bd3c (diff) | |
download | gitlab-ce-5abc37bd85ca3ab28f7fb6fdbb6db8161f51d8fb.tar.gz |
Merge branch 'make-epics-position-migration-robust' into 'master'
Make epic_issues relative_position migration more robust
Closes #66923
See merge request gitlab-org/gitlab-ce!32646
Diffstat (limited to 'db')
-rw-r--r-- | db/migrate/20190806071559_remove_epic_issues_default_relative_position.rb | 21 |
1 files changed, 18 insertions, 3 deletions
diff --git a/db/migrate/20190806071559_remove_epic_issues_default_relative_position.rb b/db/migrate/20190806071559_remove_epic_issues_default_relative_position.rb index f6db90f6637..3037f2ea106 100644 --- a/db/migrate/20190806071559_remove_epic_issues_default_relative_position.rb +++ b/db/migrate/20190806071559_remove_epic_issues_default_relative_position.rb @@ -3,8 +3,23 @@ class RemoveEpicIssuesDefaultRelativePosition < ActiveRecord::Migration[5.2] DOWNTIME = false - def change - change_column_null :epic_issues, :relative_position, true - change_column_default :epic_issues, :relative_position, from: 1073741823, to: nil + include Gitlab::Database::MigrationHelpers + + disable_ddl_transaction! + + def up + # The column won't exist if someone installed EE, downgraded to CE + # before it was added in EE, then tries to upgrade CE. + if column_exists?(:epic_issues, :relative_position) + change_column_null :epic_issues, :relative_position, true + change_column_default :epic_issues, :relative_position, from: 1073741823, to: nil + else + add_column_with_default(:epic_issues, :relative_position, :integer, default: nil, allow_null: true) + end + end + + def down + change_column_default :epic_issues, :relative_position, from: nil, to: 1073741823 + change_column_null :epic_issues, :relative_position, false end end |