chiya/test/chiya_web/controllers/user_session_controller_test.exs

112 lines
3.4 KiB
Elixir
Raw Normal View History

2023-03-05 16:13:00 +01:00
defmodule ChiyaWeb.UserSessionControllerTest do
use ChiyaWeb.ConnCase, async: true
import Chiya.AccountsFixtures
setup do
%{user: user_fixture()}
end
2023-03-07 21:15:26 +01:00
describe "POST /user/log_in" do
2023-03-05 16:13:00 +01:00
test "logs the user in", %{conn: conn, user: user} do
conn =
2023-03-07 21:15:26 +01:00
post(conn, ~p"/user/log_in", %{
2023-03-05 16:13:00 +01:00
"user" => %{"email" => user.email, "password" => valid_user_password()}
})
assert get_session(conn, :user_token)
assert redirected_to(conn) == ~p"/"
# Now do a logged in request and assert on the menu
conn = get(conn, ~p"/")
response = html_response(conn, 200)
2023-06-23 06:59:38 +02:00
assert response =~ ~p"/admin"
2023-03-05 16:13:00 +01:00
end
test "logs the user in with remember me", %{conn: conn, user: user} do
conn =
2023-03-07 21:15:26 +01:00
post(conn, ~p"/user/log_in", %{
2023-03-05 16:13:00 +01:00
"user" => %{
"email" => user.email,
"password" => valid_user_password(),
"remember_me" => "true"
}
})
assert conn.resp_cookies["_chiya_web_user_remember_me"]
assert redirected_to(conn) == ~p"/"
end
test "logs the user in with return to", %{conn: conn, user: user} do
conn =
conn
|> init_test_session(user_return_to: "/foo/bar")
2023-03-07 21:15:26 +01:00
|> post(~p"/user/log_in", %{
2023-03-05 16:13:00 +01:00
"user" => %{
"email" => user.email,
"password" => valid_user_password()
}
})
assert redirected_to(conn) == "/foo/bar"
assert Phoenix.Flash.get(conn.assigns.flash, :info) =~ "Welcome back!"
end
test "login following registration", %{conn: conn, user: user} do
conn =
conn
2023-03-07 21:15:26 +01:00
|> post(~p"/user/log_in", %{
2023-03-05 16:13:00 +01:00
"_action" => "registered",
"user" => %{
"email" => user.email,
"password" => valid_user_password()
}
})
assert redirected_to(conn) == ~p"/"
assert Phoenix.Flash.get(conn.assigns.flash, :info) =~ "Account created successfully"
end
test "login following password update", %{conn: conn, user: user} do
conn =
conn
2023-03-07 21:15:26 +01:00
|> post(~p"/user/log_in", %{
2023-03-05 16:13:00 +01:00
"_action" => "password_updated",
"user" => %{
"email" => user.email,
"password" => valid_user_password()
}
})
2023-03-07 21:15:26 +01:00
assert redirected_to(conn) == ~p"/user/settings"
2023-03-05 16:13:00 +01:00
assert Phoenix.Flash.get(conn.assigns.flash, :info) =~ "Password updated successfully"
end
test "redirects to login page with invalid credentials", %{conn: conn} do
conn =
2023-03-07 21:15:26 +01:00
post(conn, ~p"/user/log_in", %{
2023-03-05 16:13:00 +01:00
"user" => %{"email" => "invalid@email.com", "password" => "invalid_password"}
})
assert Phoenix.Flash.get(conn.assigns.flash, :error) == "Invalid email or password"
2023-03-07 21:15:26 +01:00
assert redirected_to(conn) == ~p"/user/log_in"
2023-03-05 16:13:00 +01:00
end
end
2023-03-07 21:15:26 +01:00
describe "DELETE /user/log_out" do
2023-03-05 16:13:00 +01:00
test "logs the user out", %{conn: conn, user: user} do
2023-03-07 21:15:26 +01:00
conn = conn |> log_in_user(user) |> delete(~p"/user/log_out")
2023-03-05 16:13:00 +01:00
assert redirected_to(conn) == ~p"/"
refute get_session(conn, :user_token)
assert Phoenix.Flash.get(conn.assigns.flash, :info) =~ "Logged out successfully"
end
test "succeeds even if the user is not logged in", %{conn: conn} do
2023-03-07 21:15:26 +01:00
conn = delete(conn, ~p"/user/log_out")
2023-03-05 16:13:00 +01:00
assert redirected_to(conn) == ~p"/"
refute get_session(conn, :user_token)
assert Phoenix.Flash.get(conn.assigns.flash, :info) =~ "Logged out successfully"
end
end
end