2020-05-07 08:14:54 +00:00
|
|
|
# Pleroma: A lightweight social networking server
|
2021-01-13 06:49:20 +00:00
|
|
|
# Copyright © 2017-2021 Pleroma Authors <https://pleroma.social/>
|
2020-05-07 08:14:54 +00:00
|
|
|
# SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
|
|
|
|
defmodule Pleroma.Web.Auth.PleromaAuthenticatorTest do
|
2023-08-01 10:43:50 +00:00
|
|
|
use Pleroma.Web.ConnCase, async: false
|
2020-05-07 08:14:54 +00:00
|
|
|
|
|
|
|
alias Pleroma.Web.Auth.PleromaAuthenticator
|
|
|
|
import Pleroma.Factory
|
|
|
|
|
|
|
|
setup do
|
|
|
|
password = "testpassword"
|
|
|
|
name = "AgentSmith"
|
2021-01-14 15:01:14 +00:00
|
|
|
|
|
|
|
user =
|
|
|
|
insert(:user,
|
|
|
|
nickname: name,
|
2022-12-30 02:46:58 +00:00
|
|
|
password_hash: Pleroma.Password.hash_pwd_salt(password)
|
2021-01-14 15:01:14 +00:00
|
|
|
)
|
|
|
|
|
2020-05-07 08:14:54 +00:00
|
|
|
{:ok, [user: user, name: name, password: password]}
|
|
|
|
end
|
|
|
|
|
2020-05-17 09:53:17 +00:00
|
|
|
test "get_user/authorization", %{name: name, password: password} do
|
|
|
|
name = name <> "1"
|
|
|
|
user = insert(:user, nickname: name, password_hash: Bcrypt.hash_pwd_salt(password))
|
|
|
|
|
2020-05-07 08:14:54 +00:00
|
|
|
params = %{"authorization" => %{"name" => name, "password" => password}}
|
|
|
|
res = PleromaAuthenticator.get_user(%Plug.Conn{params: params})
|
|
|
|
|
2020-05-17 09:53:17 +00:00
|
|
|
assert {:ok, returned_user} = res
|
|
|
|
assert returned_user.id == user.id
|
2022-12-30 02:46:58 +00:00
|
|
|
assert "$argon2" <> _ = returned_user.password_hash
|
2020-05-07 08:14:54 +00:00
|
|
|
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
|