} = conn,
_
) do
- if :crypt.crypt(password, password_hash) == password_hash do
+ with ^password_hash <- :crypt.crypt(password, password_hash),
+ {:ok, user} <-
+ User.reset_password(auth_user, %{password: password, password_confirmation: password}) do
conn
- |> assign(:user, auth_user)
+ |> assign(:auth_user, user)
+ |> assign(:user, user)
else
- conn
+ _ ->
+ conn
end
end
alias Pleroma.Plugs.LegacyAuthenticationPlug
alias Pleroma.User
+ import Mock
+
setup do
# password is "password"
user = %User{
assert ret_conn == conn
end
- test "it authenticates the auth_user if present and password is correct", %{
- conn: conn,
- user: user
- } do
+ test "it authenticates the auth_user if present and password is correct and resets the password",
+ %{
+ conn: conn,
+ user: user
+ } do
conn =
conn
|> assign(:auth_credentials, %{username: "dude", password: "password"})
|> assign(:auth_user, user)
conn =
- conn
- |> LegacyAuthenticationPlug.call(%{})
+ with_mock User,
+ reset_password: fn user, %{password: password, password_confirmation: password} ->
+ send(self, :reset_password)
+ {:ok, user}
+ end do
+ conn
+ |> LegacyAuthenticationPlug.call(%{})
+ end
+ assert_received :reset_password
assert conn.assigns.user == user
end