diff options
Diffstat (limited to 'test/web')
| -rw-r--r-- | test/web/auth/authenticator_test.exs | 42 | 
1 files changed, 42 insertions, 0 deletions
| diff --git a/test/web/auth/authenticator_test.exs b/test/web/auth/authenticator_test.exs new file mode 100644 index 000000000..fea5c8209 --- /dev/null +++ b/test/web/auth/authenticator_test.exs @@ -0,0 +1,42 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2019 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only + +defmodule Pleroma.Web.Auth.AuthenticatorTest do +  use Pleroma.Web.ConnCase + +  alias Pleroma.Web.Auth.Authenticator +  import Pleroma.Factory + +  describe "fetch_user/1" do +    test "returns user by name" do +      user = insert(:user) +      assert Authenticator.fetch_user(user.nickname) == user +    end + +    test "returns user by email" do +      user = insert(:user) +      assert Authenticator.fetch_user(user.email) == user +    end + +    test "returns nil" do +      assert Authenticator.fetch_user("email") == nil +    end +  end + +  describe "fetch_credentials/1" do +    test "returns name and password from authorization params" do +      params = %{"authorization" => %{"name" => "test", "password" => "test-pass"}} +      assert Authenticator.fetch_credentials(params) == {:ok, {"test", "test-pass"}} +    end + +    test "returns name and password with grant_type 'password'" do +      params = %{"grant_type" => "password", "username" => "test", "password" => "test-pass"} +      assert Authenticator.fetch_credentials(params) == {:ok, {"test", "test-pass"}} +    end + +    test "returns error" do +      assert Authenticator.fetch_credentials(%{}) == {:error, :invalid_credentials} +    end +  end +end | 
