| defmodule MedicodeWeb.UserSessionControllerTest do |
| use MedicodeWeb.ConnCase, async: true |
|
|
| import Medicode.AccountsFixtures |
|
|
| setup do |
| %{user: user_fixture()} |
| end |
|
|
| describe "POST /users/log_in" do |
| test "logs the user in", %{conn: conn, user: user} do |
| conn = |
| post(conn, ~p"/users/log_in", %{ |
| "user" => %{"email" => user.email, "password" => valid_user_password()} |
| }) |
|
|
| assert get_session(conn, :user_token) |
| assert redirected_to(conn) == ~p"/" |
|
|
| |
| conn = get(conn, ~p"/") |
| response = html_response(conn, 200) |
| assert response =~ user.email |
| assert response =~ ~p"/users/settings" |
| assert response =~ ~p"/users/log_out" |
| end |
|
|
| test "logs the user in with remember me", %{conn: conn, user: user} do |
| conn = |
| post(conn, ~p"/users/log_in", %{ |
| "user" => %{ |
| "email" => user.email, |
| "password" => valid_user_password(), |
| "remember_me" => "true" |
| } |
| }) |
|
|
| assert conn.resp_cookies["_medicode_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") |
| |> post(~p"/users/log_in", %{ |
| "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 |
| |> post(~p"/users/log_in", %{ |
| "_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 |
| |> post(~p"/users/log_in", %{ |
| "_action" => "password_updated", |
| "user" => %{ |
| "email" => user.email, |
| "password" => valid_user_password() |
| } |
| }) |
|
|
| assert redirected_to(conn) == ~p"/users/settings" |
| assert Phoenix.Flash.get(conn.assigns.flash, :info) =~ "Password updated successfully" |
| end |
|
|
| test "redirects to login page with invalid credentials", %{conn: conn} do |
| conn = |
| post(conn, ~p"/users/log_in", %{ |
| "user" => %{"email" => "invalid@email.com", "password" => "invalid_password"} |
| }) |
|
|
| assert Phoenix.Flash.get(conn.assigns.flash, :error) == "Invalid email or password" |
| assert redirected_to(conn) == ~p"/users/log_in" |
| end |
| end |
|
|
| describe "DELETE /users/log_out" do |
| test "logs the user out", %{conn: conn, user: user} do |
| conn = conn |> log_in_user(user) |> delete(~p"/users/log_out") |
| assert redirected_to(conn) == ~p"/users/log_in" |
| 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 |
| conn = delete(conn, ~p"/users/log_out") |
| assert redirected_to(conn) == ~p"/users/log_in" |
| refute get_session(conn, :user_token) |
| assert Phoenix.Flash.get(conn.assigns.flash, :info) =~ "Logged out successfully" |
| end |
| end |
| end |
|
|