diff options
Diffstat (limited to 'test/object')
| -rw-r--r-- | test/object/containment_test.exs | 6 | ||||
| -rw-r--r-- | test/object/fetcher_test.exs | 34 | 
2 files changed, 34 insertions, 6 deletions
| diff --git a/test/object/containment_test.exs b/test/object/containment_test.exs index a7a046203..a860355b8 100644 --- a/test/object/containment_test.exs +++ b/test/object/containment_test.exs @@ -5,6 +5,7 @@ defmodule Pleroma.Object.ContainmentTest do    alias Pleroma.User    import Pleroma.Factory +  import ExUnit.CaptureLog    setup_all do      Tesla.Mock.mock_global(fn env -> apply(HttpRequestMock, :request, [env]) end) @@ -57,7 +58,10 @@ defmodule Pleroma.Object.ContainmentTest do            follower_address: User.ap_followers(%User{nickname: "rye@niu.moe"})          }) -      {:error, _} = User.get_or_fetch_by_ap_id("https://n1u.moe/users/rye") +      assert capture_log(fn -> +               {:error, _} = User.get_or_fetch_by_ap_id("https://n1u.moe/users/rye") +             end) =~ +               "[error] Could not decode user at fetch https://n1u.moe/users/rye, {:error, :error}"      end    end  end diff --git a/test/object/fetcher_test.exs b/test/object/fetcher_test.exs index d604fd5f5..26dc9496d 100644 --- a/test/object/fetcher_test.exs +++ b/test/object/fetcher_test.exs @@ -7,7 +7,17 @@ defmodule Pleroma.Object.FetcherTest do    import Tesla.Mock    setup do -    mock(fn env -> apply(HttpRequestMock, :request, [env]) end) +    mock(fn +      %{method: :get, url: "https://mastodon.example.org/users/userisgone"} -> +        %Tesla.Env{status: 410} + +      %{method: :get, url: "https://mastodon.example.org/users/userisgone404"} -> +        %Tesla.Env{status: 404} + +      env -> +        apply(HttpRequestMock, :request, [env]) +    end) +      :ok    end @@ -81,10 +91,24 @@ defmodule Pleroma.Object.FetcherTest do      end      test "all objects with fake directions are rejected by the object fetcher" do -      {:error, _} = -        Fetcher.fetch_and_contain_remote_object_from_id( -          "https://info.pleroma.site/activity4.json" -        ) +      assert {:error, _} = +               Fetcher.fetch_and_contain_remote_object_from_id( +                 "https://info.pleroma.site/activity4.json" +               ) +    end + +    test "handle HTTP 410 Gone response" do +      assert {:error, "Object has been deleted"} == +               Fetcher.fetch_and_contain_remote_object_from_id( +                 "https://mastodon.example.org/users/userisgone" +               ) +    end + +    test "handle HTTP 404 response" do +      assert {:error, "Object has been deleted"} == +               Fetcher.fetch_and_contain_remote_object_from_id( +                 "https://mastodon.example.org/users/userisgone404" +               )      end    end | 
