9ba60f70d2
In general, tests that match these criteria can be made async: - Doesn't use real Cachex. - Doesn't write to the Config / Application Environment. - Uses Mock. Using Mox is fine. - Uses the streamer.
48 lines
1.7 KiB
Elixir
48 lines
1.7 KiB
Elixir
# Pleroma: A lightweight social networking server
|
|
# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>
|
|
# SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
defmodule Pleroma.Web.Auth.PleromaAuthenticatorTest do
|
|
use Pleroma.Web.ConnCase, async: true
|
|
|
|
alias Pleroma.Web.Auth.PleromaAuthenticator
|
|
import Pleroma.Factory
|
|
|
|
setup do
|
|
password = "testpassword"
|
|
name = "AgentSmith"
|
|
user = insert(:user, nickname: name, password_hash: Pbkdf2.hash_pwd_salt(password))
|
|
{:ok, [user: user, name: name, password: password]}
|
|
end
|
|
|
|
test "get_user/authorization", %{name: name, password: password} do
|
|
name = name <> "1"
|
|
user = insert(:user, nickname: name, password_hash: Bcrypt.hash_pwd_salt(password))
|
|
|
|
params = %{"authorization" => %{"name" => name, "password" => password}}
|
|
res = PleromaAuthenticator.get_user(%Plug.Conn{params: params})
|
|
|
|
assert {:ok, returned_user} = res
|
|
assert returned_user.id == user.id
|
|
assert "$pbkdf2" <> _ = returned_user.password_hash
|
|
end
|
|
|
|
test "get_user/authorization with invalid password", %{name: name} do
|
|
params = %{"authorization" => %{"name" => name, "password" => "password"}}
|
|
res = PleromaAuthenticator.get_user(%Plug.Conn{params: params})
|
|
|
|
assert {:error, {:checkpw, false}} == res
|
|
end
|
|
|
|
test "get_user/grant_type_password", %{user: user, name: name, password: password} do
|
|
params = %{"grant_type" => "password", "username" => name, "password" => password}
|
|
res = PleromaAuthenticator.get_user(%Plug.Conn{params: params})
|
|
|
|
assert {:ok, user} == res
|
|
end
|
|
|
|
test "error credintails" do
|
|
res = PleromaAuthenticator.get_user(%Plug.Conn{params: %{}})
|
|
assert {:error, :invalid_credentials} == res
|
|
end
|
|
end
|