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