Migration to confirm previously-logged-in users
This commit is contained in:
parent
64f0e96ff6
commit
7b44605cb8
|
@ -0,0 +1,22 @@
|
||||||
|
# Pleroma: A lightweight social networking server
|
||||||
|
# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>
|
||||||
|
# SPDX-License-Identifier: AGPL-3.0-only
|
||||||
|
|
||||||
|
defmodule Pleroma.Repo.Migrations.ConfirmLoggedInUsers do
|
||||||
|
use Ecto.Migration
|
||||||
|
import Ecto.Query
|
||||||
|
alias Pleroma.Repo
|
||||||
|
alias Pleroma.User
|
||||||
|
alias Pleroma.Web.OAuth.Token
|
||||||
|
|
||||||
|
def up do
|
||||||
|
User
|
||||||
|
|> where([u], u.confirmation_pending == true)
|
||||||
|
|> join(:inner, [u], t in Token, on: t.user_id == u.id)
|
||||||
|
|> Repo.update_all(set: [confirmation_pending: false])
|
||||||
|
end
|
||||||
|
|
||||||
|
def down do
|
||||||
|
:noop
|
||||||
|
end
|
||||||
|
end
|
|
@ -0,0 +1,40 @@
|
||||||
|
# Pleroma: A lightweight social networking server
|
||||||
|
# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>
|
||||||
|
# SPDX-License-Identifier: AGPL-3.0-only
|
||||||
|
|
||||||
|
defmodule Pleroma.Repo.Migrations.ConfirmLoggedInUsersTest do
|
||||||
|
alias Pleroma.Repo
|
||||||
|
alias Pleroma.User
|
||||||
|
use Pleroma.DataCase, async: true
|
||||||
|
import Ecto.Query
|
||||||
|
import Pleroma.Factory
|
||||||
|
import Pleroma.Tests.Helpers
|
||||||
|
|
||||||
|
setup_all do: require_migration("20201231185546_confirm_logged_in_users")
|
||||||
|
|
||||||
|
test "up/0 confirms unconfirmed but previously-logged-in users", %{migration: migration} do
|
||||||
|
insert_list(25, :oauth_token)
|
||||||
|
Repo.update_all(User, set: [confirmation_pending: true])
|
||||||
|
insert_list(5, :user, confirmation_pending: true)
|
||||||
|
|
||||||
|
count =
|
||||||
|
User
|
||||||
|
|> where(confirmation_pending: true)
|
||||||
|
|> Repo.aggregate(:count)
|
||||||
|
|
||||||
|
assert count == 30
|
||||||
|
|
||||||
|
assert {25, nil} == migration.up()
|
||||||
|
|
||||||
|
count =
|
||||||
|
User
|
||||||
|
|> where(confirmation_pending: true)
|
||||||
|
|> Repo.aggregate(:count)
|
||||||
|
|
||||||
|
assert count == 5
|
||||||
|
end
|
||||||
|
|
||||||
|
test "down/0 does nothing", %{migration: migration} do
|
||||||
|
assert :noop == migration.down()
|
||||||
|
end
|
||||||
|
end
|
Loading…
Reference in New Issue