summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndreas Brandl <abrandl@gitlab.com>2019-09-09 12:48:48 +0000
committerAndreas Brandl <abrandl@gitlab.com>2019-09-09 12:48:48 +0000
commit5abc37bd85ca3ab28f7fb6fdbb6db8161f51d8fb (patch)
treeac9e26ba745c7ade7711b5026c70d77ff3d5cd0e
parentb5343bba31687dabdb7ede19cab453c3294b162c (diff)
parentd1c761b3e93ec09ba3f77ba7f4b2f229c425bd3c (diff)
downloadgitlab-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
-rw-r--r--db/migrate/20190806071559_remove_epic_issues_default_relative_position.rb21
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