Migration to confirm previously-logged-in users

This commit is contained in:
Alex Gleason 2020-12-31 14:04:51 -06:00
parent 64f0e96ff6
commit 7b44605cb8
No known key found for this signature in database
GPG key ID: 7211D1F99744FBB7
2 changed files with 62 additions and 0 deletions

View file

@ -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

View file

@ -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