diff options
author | rinpatch <rinpatch@sdf.org> | 2020-05-01 16:48:31 +0000 |
---|---|---|
committer | rinpatch <rinpatch@sdf.org> | 2020-05-01 16:48:31 +0000 |
commit | ed8282c0910e5a07b87a6efbf4eb34208a8f39e1 (patch) | |
tree | 74ac34a1f24e98c7f3f2d94fe564cf9ab18c9816 /test | |
parent | ed4e9e6435cdc4740cf12464f01ffdb5a6a96583 (diff) | |
parent | 3453e54e6b00ca2aced07746ad4cfc22ebc404fb (diff) | |
download | pleroma-ed8282c0910e5a07b87a6efbf4eb34208a8f39e1.tar.gz |
Merge branch 'bugfix/1727-fix-signature-decoding' into 'develop'
Bugfix/1727 fix signature decoding
Closes #1727
See merge request pleroma/pleroma!2454
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 |