diff options
| author | lain <lain@soykaf.club> | 2020-05-01 15:54:38 +0200 | 
|---|---|---|
| committer | lain <lain@soykaf.club> | 2020-05-01 15:54:38 +0200 | 
| commit | a912f72a3674f80fe665db466295192b4dab82a9 (patch) | |
| tree | 3cd70fc66b71c728c82bb0803e8090596daad86e /test | |
| parent | 3370bb0e46413d35810b8d2740cc3e92646d6324 (diff) | |
| download | pleroma-a912f72a3674f80fe665db466295192b4dab82a9.tar.gz pleroma-a912f72a3674f80fe665db466295192b4dab82a9.zip | |
Signature: Handle non-ap ids in key ids.
Mastodon and Gab sometimes send the format `acct:name@server`.
Diffstat (limited to 'test')
| -rw-r--r-- | test/signature_test.exs | 18 | 
1 files changed, 14 insertions, 4 deletions
| diff --git a/test/signature_test.exs b/test/signature_test.exs index d5a2a62c4..a7a75aa4d 100644 --- a/test/signature_test.exs +++ b/test/signature_test.exs @@ -44,7 +44,8 @@ defmodule Pleroma.SignatureTest do      test "it returns error when not found user" do        assert capture_log(fn -> -               assert Signature.fetch_public_key(make_fake_conn("test-ap_id")) == {:error, :error} +               assert Signature.fetch_public_key(make_fake_conn("https://test-ap-id")) == +                        {:error, :error}               end) =~ "[error] Could not decode user"      end @@ -64,7 +65,7 @@ defmodule Pleroma.SignatureTest do      test "it returns error when not found user" do        assert capture_log(fn -> -               {:error, _} = Signature.refetch_public_key(make_fake_conn("test-ap_id")) +               {:error, _} = Signature.refetch_public_key(make_fake_conn("https://test-ap_id"))               end) =~ "[error] Could not decode user"      end    end @@ -100,12 +101,21 @@ defmodule Pleroma.SignatureTest do    describe "key_id_to_actor_id/1" do      test "it properly deduces the actor id for misskey" do        assert Signature.key_id_to_actor_id("https://example.com/users/1234/publickey") == -               "https://example.com/users/1234" +               {:ok, "https://example.com/users/1234"}      end      test "it properly deduces the actor id for mastodon and pleroma" do        assert Signature.key_id_to_actor_id("https://example.com/users/1234#main-key") == -               "https://example.com/users/1234" +               {:ok, "https://example.com/users/1234"} +    end + +    test "it calls webfinger for 'acct:' accounts" do +      with_mock(Pleroma.Web.WebFinger, +        finger: fn _ -> %{"ap_id" => "https://gensokyo.2hu/users/raymoo"} end +      ) do +        assert Signature.key_id_to_actor_id("acct:raymoo@gensokyo.2hu") == +                 {:ok, "https://gensokyo.2hu/users/raymoo"} +      end      end    end | 
