aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorfeld <feld@feld.me>2019-07-03 16:54:47 +0000
committerfeld <feld@feld.me>2019-07-03 16:54:47 +0000
commit9b45feae9b5102acb7b9431faa7eaaffcd7e634f (patch)
treeabf5eb6ed8ea03012c1657f54a5fa10bd5f3cc07
parent079266d40658ee7042f7bc8a855485069a474ef8 (diff)
parentefefee82415d872209cf5884375891e577f54781 (diff)
downloadpleroma-9b45feae9b5102acb7b9431faa7eaaffcd7e634f.tar.gz
Merge branch 'fix/migration-alter-citext-field-with-key' into 'develop'
Fix occasional migration failures See merge request pleroma/pleroma!1373
-rw-r--r--priv/repo/migrations/20170522160642_case_insensivtivity.exs24
1 files changed, 18 insertions, 6 deletions
diff --git a/priv/repo/migrations/20170522160642_case_insensivtivity.exs b/priv/repo/migrations/20170522160642_case_insensivtivity.exs
index c7565946e..9a67727e9 100644
--- a/priv/repo/migrations/20170522160642_case_insensivtivity.exs
+++ b/priv/repo/migrations/20170522160642_case_insensivtivity.exs
@@ -1,19 +1,31 @@
defmodule Pleroma.Repo.Migrations.CaseInsensivtivity do
use Ecto.Migration
+ # Two-steps alters are intentional.
+ # When alter of 2 columns is done in a single operation,
+ # inconsistent failures happen because of index on `email` column.
+
def up do
- execute ("create extension if not exists citext")
+ execute("create extension if not exists citext")
+
+ alter table(:users) do
+ modify(:email, :citext)
+ end
+
alter table(:users) do
- modify :email, :citext
- modify :nickname, :citext
+ modify(:nickname, :citext)
end
end
def down do
alter table(:users) do
- modify :email, :string
- modify :nickname, :string
+ modify(:email, :string)
end
- execute ("drop extension if exists citext")
+
+ alter table(:users) do
+ modify(:nickname, :string)
+ end
+
+ execute("drop extension if exists citext")
end
end