2026-02-18 21:23:15 +00:00
|
|
|
defmodule BerrypodWeb.Auth.ConfirmationTest do
|
|
|
|
|
use BerrypodWeb.ConnCase
|
2025-12-30 12:26:46 +00:00
|
|
|
|
|
|
|
|
import Phoenix.LiveViewTest
|
2026-02-18 21:23:15 +00:00
|
|
|
import Berrypod.AccountsFixtures
|
2025-12-30 12:26:46 +00:00
|
|
|
|
2026-02-18 21:23:15 +00:00
|
|
|
alias Berrypod.Accounts
|
2025-12-30 12:26:46 +00:00
|
|
|
|
|
|
|
|
setup do
|
|
|
|
|
%{unconfirmed_user: unconfirmed_user_fixture(), confirmed_user: user_fixture()}
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
describe "Confirm user" do
|
|
|
|
|
test "renders confirmation page for unconfirmed user", %{conn: conn, unconfirmed_user: user} do
|
|
|
|
|
token =
|
|
|
|
|
extract_user_token(fn url ->
|
|
|
|
|
Accounts.deliver_login_instructions(user, url)
|
|
|
|
|
end)
|
|
|
|
|
|
|
|
|
|
{:ok, _lv, html} = live(conn, ~p"/users/log-in/#{token}")
|
|
|
|
|
assert html =~ "Confirm and stay logged in"
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
test "renders login page for confirmed user", %{conn: conn, confirmed_user: user} do
|
|
|
|
|
token =
|
|
|
|
|
extract_user_token(fn url ->
|
|
|
|
|
Accounts.deliver_login_instructions(user, url)
|
|
|
|
|
end)
|
|
|
|
|
|
|
|
|
|
{:ok, _lv, html} = live(conn, ~p"/users/log-in/#{token}")
|
|
|
|
|
refute html =~ "Confirm my account"
|
|
|
|
|
assert html =~ "Keep me logged in on this device"
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
test "renders login page for already logged in user", %{conn: conn, confirmed_user: user} do
|
|
|
|
|
conn = log_in_user(conn, user)
|
|
|
|
|
|
|
|
|
|
token =
|
|
|
|
|
extract_user_token(fn url ->
|
|
|
|
|
Accounts.deliver_login_instructions(user, url)
|
|
|
|
|
end)
|
|
|
|
|
|
|
|
|
|
{:ok, _lv, html} = live(conn, ~p"/users/log-in/#{token}")
|
|
|
|
|
refute html =~ "Confirm my account"
|
|
|
|
|
assert html =~ "Log in"
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
test "confirms the given token once", %{conn: conn, unconfirmed_user: user} do
|
|
|
|
|
token =
|
|
|
|
|
extract_user_token(fn url ->
|
|
|
|
|
Accounts.deliver_login_instructions(user, url)
|
|
|
|
|
end)
|
|
|
|
|
|
|
|
|
|
{:ok, lv, _html} = live(conn, ~p"/users/log-in/#{token}")
|
|
|
|
|
|
|
|
|
|
form = form(lv, "#confirmation_form", %{"user" => %{"token" => token}})
|
|
|
|
|
render_submit(form)
|
|
|
|
|
|
|
|
|
|
conn = follow_trigger_action(form, conn)
|
|
|
|
|
|
|
|
|
|
assert Phoenix.Flash.get(conn.assigns.flash, :info) =~
|
|
|
|
|
"User confirmed successfully"
|
|
|
|
|
|
|
|
|
|
assert Accounts.get_user!(user.id).confirmed_at
|
|
|
|
|
# we are logged in now
|
|
|
|
|
assert get_session(conn, :user_token)
|
2026-02-18 23:55:42 +00:00
|
|
|
assert redirected_to(conn) == ~p"/admin/setup"
|
2025-12-30 12:26:46 +00:00
|
|
|
|
|
|
|
|
# log out, new conn
|
|
|
|
|
conn = build_conn()
|
|
|
|
|
|
|
|
|
|
{:ok, _lv, html} =
|
|
|
|
|
live(conn, ~p"/users/log-in/#{token}")
|
|
|
|
|
|> follow_redirect(conn, ~p"/users/log-in")
|
|
|
|
|
|
|
|
|
|
assert html =~ "Magic link is invalid or it has expired"
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
test "logs confirmed user in without changing confirmed_at", %{
|
|
|
|
|
conn: conn,
|
|
|
|
|
confirmed_user: user
|
|
|
|
|
} do
|
|
|
|
|
token =
|
|
|
|
|
extract_user_token(fn url ->
|
|
|
|
|
Accounts.deliver_login_instructions(user, url)
|
|
|
|
|
end)
|
|
|
|
|
|
|
|
|
|
{:ok, lv, _html} = live(conn, ~p"/users/log-in/#{token}")
|
|
|
|
|
|
|
|
|
|
form = form(lv, "#login_form", %{"user" => %{"token" => token}})
|
|
|
|
|
render_submit(form)
|
|
|
|
|
|
|
|
|
|
conn = follow_trigger_action(form, conn)
|
|
|
|
|
|
|
|
|
|
assert Phoenix.Flash.get(conn.assigns.flash, :info) =~
|
|
|
|
|
"Welcome back!"
|
|
|
|
|
|
|
|
|
|
assert Accounts.get_user!(user.id).confirmed_at == user.confirmed_at
|
|
|
|
|
|
|
|
|
|
# log out, new conn
|
|
|
|
|
conn = build_conn()
|
|
|
|
|
|
|
|
|
|
{:ok, _lv, html} =
|
|
|
|
|
live(conn, ~p"/users/log-in/#{token}")
|
|
|
|
|
|> follow_redirect(conn, ~p"/users/log-in")
|
|
|
|
|
|
|
|
|
|
assert html =~ "Magic link is invalid or it has expired"
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
test "raises error for invalid token", %{conn: conn} do
|
|
|
|
|
{:ok, _lv, html} =
|
|
|
|
|
live(conn, ~p"/users/log-in/invalid-token")
|
|
|
|
|
|> follow_redirect(conn, ~p"/users/log-in")
|
|
|
|
|
|
|
|
|
|
assert html =~ "Magic link is invalid or it has expired"
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
end
|