summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRoman Chvanikov <chvanikoff@pm.me>2019-07-03 14:56:02 +0300
committerRoman Chvanikov <chvanikoff@pm.me>2019-07-03 14:56:02 +0300
commitefefee82415d872209cf5884375891e577f54781 (patch)
treefa88a6a233de02a5adbff7ebdcd39931ebf09e0f
parent291d95dcc3cd85050421d2ab022e01a6d89c0f3d (diff)
downloadpleroma-efefee82415d872209cf5884375891e577f54781.tar.gz
pleroma-efefee82415d872209cf5884375891e577f54781.zip
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