Skip to content

Commit

Permalink
feat(ex/test/conn-case): make default user dynamic from factory
Browse files Browse the repository at this point in the history
  • Loading branch information
firestack committed Oct 25, 2024
2 parents 0e5797c + 86109ea commit 372eba7
Showing 1 changed file with 42 additions and 37 deletions.
79 changes: 42 additions & 37 deletions test/support/conn_case.ex
Original file line number Diff line number Diff line change
Expand Up @@ -14,8 +14,6 @@ defmodule SkateWeb.ConnCase do
"""

use ExUnit.CaseTemplate
import Plug.Test
alias Skate.Settings.User

using do
quote do
Expand All @@ -33,57 +31,64 @@ defmodule SkateWeb.ConnCase do

setup tags do
alias Ecto.Adapters.SQL.Sandbox

:ok = Sandbox.checkout(Skate.Repo)
username = "test_user"
email = "[email protected]"

unless tags[:async] do
Sandbox.mode(Skate.Repo, {:shared, self()})
end

user = User.upsert(username, email)
resource = %{id: user.id}
setup_from_tags(tags)
end

def setup_from_tags(%{authenticated: true}) do
user = create_default_user()

{conn, user} =
cond do
tags[:authenticated] ->
User.upsert(username, email)
conn =
Phoenix.ConnTest.build_conn()
|> Phoenix.ConnTest.init_test_session(%{})
|> Guardian.Plug.sign_in(SkateWeb.AuthManager, resource_from_user(user), %{})

conn =
Phoenix.ConnTest.build_conn()
|> init_test_session(%{})
|> Guardian.Plug.sign_in(SkateWeb.AuthManager, resource, %{})
{:ok, %{conn: conn, user: user}}
end

{conn, user}
def setup_from_tags(%{authenticated_admin: true}) do
user = create_default_user()

tags[:authenticated_admin] ->
User.upsert(username, email)
conn =
Phoenix.ConnTest.build_conn()
|> Phoenix.ConnTest.init_test_session(%{})
|> Guardian.Plug.sign_in(SkateWeb.AuthManager, resource_from_user(user), %{
"groups" => ["skate-admin"]
})

conn =
Phoenix.ConnTest.build_conn()
|> init_test_session(%{})
|> Guardian.Plug.sign_in(SkateWeb.AuthManager, resource, %{
"groups" => ["skate-admin"]
})
{:ok, %{conn: conn, user: user}}
end

{conn, user}
def setup_from_tags(%{authenticated_dispatcher: true}) do
user = create_default_user()

tags[:authenticated_dispatcher] ->
User.upsert(username, email)
conn =
Phoenix.ConnTest.build_conn()
|> Phoenix.ConnTest.init_test_session(%{})
|> Guardian.Plug.sign_in(SkateWeb.AuthManager, resource_from_user(user), %{
"groups" => ["skate-dispatcher"]
})

conn =
Phoenix.ConnTest.build_conn()
|> init_test_session(%{})
|> Guardian.Plug.sign_in(SkateWeb.AuthManager, resource, %{
"groups" => ["skate-dispatcher"]
})
{:ok, %{conn: conn, user: user}}
end

{conn, user}
def setup_from_tags(_) do
{:ok, %{conn: Phoenix.ConnTest.build_conn(), user: nil}}
end

true ->
{Phoenix.ConnTest.build_conn(), nil}
end
# Factory to create users
defp create_default_user() do
Skate.Factory.insert(:user)
end

{:ok, %{conn: conn, user: user}}
# Creates a Guardian resource for a `User`
defp resource_from_user(%Skate.Settings.Db.User{id: id}) do
%{id: id}
end
end

0 comments on commit 372eba7

Please sign in to comment.