mirror of
https://akkoma.dev/AkkomaGang/akkoma.git
synced 2024-12-12 13:56:53 +00:00
9be6caf125
Co-authored-by: FloatingGhost <hannah@coffee-and-dreams.uk> Reviewed-on: https://akkoma.dev/AkkomaGang/akkoma/pulls/406
55 lines
1.7 KiB
Elixir
55 lines
1.7 KiB
Elixir
# Pleroma: A lightweight social networking server
|
|
# Copyright © 2017-2021 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: Pleroma.Password.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 "$argon2" <> _ = 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
|