summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRoman Chvanikov <chvanikoff@pm.me>2019-07-03 14:56:02 +0300
committerAriadne Conill <ariadne@dereferenced.org>2019-07-28 22:35:15 +0000
commit9e88ab2cad3684bc9740171fa525c78d3a7d37b8 (patch)
treedcfca6f873ca5985f8b8016b6a5e1f323daef214
parent494a611afe1dc872d0635701b781b04a84ee243d (diff)
Split alters rather than work with indexes
-rw-r--r--priv/repo/migrations/20170522160642_case_insensivtivity.exs14
1 files changed, 10 insertions, 4 deletions
diff --git a/priv/repo/migrations/20170522160642_case_insensivtivity.exs b/priv/repo/migrations/20170522160642_case_insensivtivity.exs
index 470a545e5..9a67727e9 100644
--- a/priv/repo/migrations/20170522160642_case_insensivtivity.exs
+++ b/priv/repo/migrations/20170522160642_case_insensivtivity.exs
@@ -1,22 +1,28 @@
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")
- drop_if_exists(index(:users, [:email]))
-
alter table(:users) do
modify(:email, :citext)
- modify(:nickname, :citext)
end
- create_if_not_exists(index(:users, [:email]))
+ alter table(:users) do
+ modify(:nickname, :citext)
+ end
end
def down do
alter table(:users) do
modify(:email, :string)
+ end
+
+ alter table(:users) do
modify(:nickname, :string)
end