diff options
author | Roman Chvanikov <chvanikoff@pm.me> | 2019-07-03 14:56:02 +0300 |
---|---|---|
committer | Ariadne Conill <ariadne@dereferenced.org> | 2019-07-28 22:35:15 +0000 |
commit | 9e88ab2cad3684bc9740171fa525c78d3a7d37b8 (patch) | |
tree | dcfca6f873ca5985f8b8016b6a5e1f323daef214 | |
parent | 494a611afe1dc872d0635701b781b04a84ee243d (diff) | |
download | pleroma-9e88ab2cad3684bc9740171fa525c78d3a7d37b8.tar.gz |
Split alters rather than work with indexes
-rw-r--r-- | priv/repo/migrations/20170522160642_case_insensivtivity.exs | 14 |
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 |