ark*_*diy 1 elixir phoenix-framework
我Guardian.Plug.EnsureAuthenticated在路由器管道中。如何使它在Controller测试期间通过?
我获得了Phoenix授权控制器的测试合格。这是我的解决方案:
测试/控制器/inbox_controller_test.exs:
defmodule MyApp.InboxControllerTest do
use MyApp.ConnCase
alias MyApp.User
setup do
user = %User{id: "a1234"}
{:ok, jwt, full_claims} = Guardian.encode_and_sign(user)
{:ok, %{user: user, jwt: jwt, claims: full_claims}}
end
test "lists all entries on index", %{jwt: jwt} do
conn = conn()
|> put_req_header("authorization", "Bearer #{jwt}")
|> get(inbox_path(conn, :index))
assert json_response(conn, 200)["inboxes"] == []
end
end
Run Code Online (Sandbox Code Playgroud)
config / test.exs:
config :guardian, Guardian,
serializer: MyApp.TestGuardianSerializer
Run Code Online (Sandbox Code Playgroud)
测试/支持/test_guardian_serializer.ex:
defmodule MyApp.TestGuardianSerializer do
@behaviour Guardian.Serializer
alias MyApp.User
def for_token(user = %User{}), do: { :ok, "User:#{user.id}" }
def for_token(_), do: { :error, "Unknown resource type" }
def from_token("User:" <> id) do
{:ok, %User{id: id, login: "admin"}}
end
def from_token(_), do: { :error, "Unknown resource type" }
end
Run Code Online (Sandbox Code Playgroud)
我通过创建一个测试标签解决了这个问题,该标签使用Guardian的sign_in方法创建并记录用户(api_sign_in如果在Guardian 0.14.x上使用)。然后,您可以将其应用于需要登录用户的测试,如下所示:
setup %{conn: conn} = config do
cond do
config[:login] ->
user = insert_user()
signed_conn = Guardian.Plug.sign_in(conn, user)
{:ok, conn: signed_conn}
true ->
:ok
end
end
@tag :login
test "shows page only when logged in", %{conn: conn} do
conn = get(conn, some_page_path(conn, :index))
assert html_response(conn, 200)
end
Run Code Online (Sandbox Code Playgroud)
如果您需要为断言创建的用户,则可以将其与连接一起传递:
config[:login] ->
user = insert_user()
signed_conn = Guardian.Plug.sign_in(conn, user)
{:ok, conn: signed_conn, user: user}
Run Code Online (Sandbox Code Playgroud)
并在测试中对其进行模式匹配:
@tag :login
test "shows page only when logged in", %{conn: conn, user: user} do
# ...
end
Run Code Online (Sandbox Code Playgroud)
考虑将insert_user逻辑移到setup_all块上以减少数据库操作并加快测试速度。