diff options
Diffstat (limited to 'test/support')
| -rw-r--r-- | test/support/builders/activity_builder.ex | 1 | ||||
| -rw-r--r-- | test/support/builders/user_builder.ex | 3 | ||||
| -rw-r--r-- | test/support/captcha_mock.ex | 14 | ||||
| -rw-r--r-- | test/support/channel_case.ex | 4 | ||||
| -rw-r--r-- | test/support/conn_case.ex | 6 | ||||
| -rw-r--r-- | test/support/data_case.ex | 23 | ||||
| -rw-r--r-- | test/support/factory.ex | 133 | ||||
| -rw-r--r-- | test/support/helpers.ex | 29 | ||||
| -rw-r--r-- | test/support/http_request_mock.ex | 791 | ||||
| -rw-r--r-- | test/support/httpoison_mock.ex | 883 | ||||
| -rw-r--r-- | test/support/ostatus_mock.ex | 4 | ||||
| -rw-r--r-- | test/support/web_push_http_client_mock.ex | 23 | ||||
| -rw-r--r-- | test/support/websocket_client.ex | 62 | ||||
| -rw-r--r-- | test/support/websub_mock.ex | 9 | 
14 files changed, 1090 insertions, 895 deletions
| diff --git a/test/support/builders/activity_builder.ex b/test/support/builders/activity_builder.ex index eb72d5ba9..6e5a8e059 100644 --- a/test/support/builders/activity_builder.ex +++ b/test/support/builders/activity_builder.ex @@ -1,5 +1,4 @@  defmodule Pleroma.Builders.ActivityBuilder do -  alias Pleroma.Builders.UserBuilder    alias Pleroma.Web.ActivityPub.ActivityPub    def build(data \\ %{}, opts \\ %{}) do diff --git a/test/support/builders/user_builder.ex b/test/support/builders/user_builder.ex index 7a1ca79b5..f58e1b0ad 100644 --- a/test/support/builders/user_builder.ex +++ b/test/support/builders/user_builder.ex @@ -1,5 +1,6 @@  defmodule Pleroma.Builders.UserBuilder do -  alias Pleroma.{User, Repo} +  alias Pleroma.Repo +  alias Pleroma.User    def build(data \\ %{}) do      user = %User{ diff --git a/test/support/captcha_mock.ex b/test/support/captcha_mock.ex new file mode 100644 index 000000000..ef4e68bc5 --- /dev/null +++ b/test/support/captcha_mock.ex @@ -0,0 +1,14 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2018 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only + +defmodule Pleroma.Captcha.Mock do +  alias Pleroma.Captcha.Service +  @behaviour Service + +  @impl Service +  def new, do: %{type: :mock} + +  @impl Service +  def validate(_token, _captcha, _data), do: :ok +end diff --git a/test/support/channel_case.ex b/test/support/channel_case.ex index 68995a01d..466d8986f 100644 --- a/test/support/channel_case.ex +++ b/test/support/channel_case.ex @@ -1,3 +1,7 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2018 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only +  defmodule Pleroma.Web.ChannelCase do    @moduledoc """    This module defines the test case to be used by diff --git a/test/support/conn_case.ex b/test/support/conn_case.ex index 2e6707087..ec5892ff5 100644 --- a/test/support/conn_case.ex +++ b/test/support/conn_case.ex @@ -1,3 +1,7 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2018 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only +  defmodule Pleroma.Web.ConnCase do    @moduledoc """    This module defines the test case to be used by @@ -19,6 +23,7 @@ defmodule Pleroma.Web.ConnCase do      quote do        # Import conveniences for testing with connections        use Phoenix.ConnTest +      use Pleroma.Tests.Helpers        import Pleroma.Web.Router.Helpers        # The default endpoint for testing @@ -28,6 +33,7 @@ defmodule Pleroma.Web.ConnCase do    setup tags do      Cachex.clear(:user_cache) +    Cachex.clear(:object_cache)      :ok = Ecto.Adapters.SQL.Sandbox.checkout(Pleroma.Repo)      unless tags[:async] do diff --git a/test/support/data_case.ex b/test/support/data_case.ex index 8eff0fd94..df260bd3f 100644 --- a/test/support/data_case.ex +++ b/test/support/data_case.ex @@ -1,3 +1,7 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2018 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only +  defmodule Pleroma.DataCase do    @moduledoc """    This module defines the setup for tests requiring @@ -22,11 +26,13 @@ defmodule Pleroma.DataCase do        import Ecto.Changeset        import Ecto.Query        import Pleroma.DataCase +      use Pleroma.Tests.Helpers      end    end    setup tags do      Cachex.clear(:user_cache) +    Cachex.clear(:object_cache)      :ok = Ecto.Adapters.SQL.Sandbox.checkout(Pleroma.Repo)      unless tags[:async] do @@ -36,6 +42,23 @@ defmodule Pleroma.DataCase do      :ok    end +  def ensure_local_uploader(_context) do +    uploader = Pleroma.Config.get([Pleroma.Upload, :uploader]) +    filters = Pleroma.Config.get([Pleroma.Upload, :filters]) + +    unless uploader == Pleroma.Uploaders.Local || filters != [] do +      Pleroma.Config.put([Pleroma.Upload, :uploader], Pleroma.Uploaders.Local) +      Pleroma.Config.put([Pleroma.Upload, :filters], []) + +      on_exit(fn -> +        Pleroma.Config.put([Pleroma.Upload, :uploader], uploader) +        Pleroma.Config.put([Pleroma.Upload, :filters], filters) +      end) +    end + +    :ok +  end +    @doc """    A helper that transform changeset errors to a map of messages. diff --git a/test/support/factory.ex b/test/support/factory.ex index 2889d8977..ea59912cf 100644 --- a/test/support/factory.ex +++ b/test/support/factory.ex @@ -1,3 +1,7 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2018 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only +  defmodule Pleroma.Factory do    use ExMachina.Ecto, repo: Pleroma.Repo @@ -19,7 +23,7 @@ defmodule Pleroma.Factory do      }    end -  def note_factory do +  def note_factory(attrs \\ %{}) do      text = sequence(:text, &"This is :moominmamma: note #{&1}")      user = insert(:user) @@ -42,7 +46,7 @@ defmodule Pleroma.Factory do      }      %Pleroma.Object{ -      data: data +      data: merge_attributes(data, Map.get(attrs, :data, %{}))      }    end @@ -53,6 +57,24 @@ defmodule Pleroma.Factory do      %Pleroma.Object{data: Map.merge(data, %{"to" => [user2.ap_id]})}    end +  def article_factory do +    note_factory() +    |> Map.put("type", "Article") +  end + +  def tombstone_factory do +    data = %{ +      "type" => "Tombstone", +      "id" => Pleroma.Web.ActivityPub.Utils.generate_object_id(), +      "formerType" => "Note", +      "deleted" => DateTime.utc_now() |> DateTime.to_iso8601() +    } + +    %Pleroma.Object{ +      data: data +    } +  end +    def direct_note_activity_factory do      dm = insert(:direct_note) @@ -73,8 +95,8 @@ defmodule Pleroma.Factory do      }    end -  def note_activity_factory do -    note = insert(:note) +  def note_activity_factory(attrs \\ %{}) do +    note = attrs[:note] || insert(:note)      data = %{        "id" => Pleroma.Web.ActivityPub.Utils.generate_activity_id(), @@ -93,9 +115,29 @@ defmodule Pleroma.Factory do      }    end -  def announce_activity_factory do -    note_activity = insert(:note_activity) -    user = insert(:user) +  def article_activity_factory do +    article = insert(:article) + +    data = %{ +      "id" => Pleroma.Web.ActivityPub.Utils.generate_activity_id(), +      "type" => "Create", +      "actor" => article.data["actor"], +      "to" => article.data["to"], +      "object" => article.data, +      "published" => DateTime.utc_now() |> DateTime.to_iso8601(), +      "context" => article.data["context"] +    } + +    %Pleroma.Activity{ +      data: data, +      actor: data["actor"], +      recipients: data["to"] +    } +  end + +  def announce_activity_factory(attrs \\ %{}) do +    note_activity = attrs[:note_activity] || insert(:note_activity) +    user = attrs[:user] || insert(:user)      data = %{        "type" => "Announce", @@ -151,7 +193,7 @@ defmodule Pleroma.Factory do    def websub_subscription_factory do      %Pleroma.Web.Websub.WebsubServerSubscription{        topic: "http://example.org", -      callback: "http://example/org/callback", +      callback: "http://example.org/callback",        secret: "here's a secret",        valid_until: NaiveDateTime.add(NaiveDateTime.utc_now(), 100),        state: "requested" @@ -172,10 +214,81 @@ defmodule Pleroma.Factory do      %Pleroma.Web.OAuth.App{        client_name: "Some client",        redirect_uris: "https://example.com/callback", -      scopes: "read", +      scopes: ["read", "write", "follow", "push"],        website: "https://example.com", -      client_id: "aaabbb==", +      client_id: Ecto.UUID.generate(),        client_secret: "aaa;/&bbb"      }    end + +  def instance_factory do +    %Pleroma.Instances.Instance{ +      host: "domain.com", +      unreachable_since: nil +    } +  end + +  def oauth_token_factory do +    oauth_app = insert(:oauth_app) + +    %Pleroma.Web.OAuth.Token{ +      token: :crypto.strong_rand_bytes(32) |> Base.url_encode64(), +      refresh_token: :crypto.strong_rand_bytes(32) |> Base.url_encode64(), +      user: build(:user), +      app_id: oauth_app.id, +      valid_until: NaiveDateTime.add(NaiveDateTime.utc_now(), 60 * 10) +    } +  end + +  def oauth_authorization_factory do +    %Pleroma.Web.OAuth.Authorization{ +      token: :crypto.strong_rand_bytes(32) |> Base.url_encode64(padding: false), +      scopes: ["read", "write", "follow", "push"], +      valid_until: NaiveDateTime.add(NaiveDateTime.utc_now(), 60 * 10), +      user: build(:user), +      app: build(:oauth_app) +    } +  end + +  def push_subscription_factory do +    %Pleroma.Web.Push.Subscription{ +      user: build(:user), +      token: build(:oauth_token), +      endpoint: "https://example.com/example/1234", +      key_auth: "8eDyX_uCN0XRhSbY5hs7Hg==", +      key_p256dh: +        "BCIWgsnyXDv1VkhqL2P7YRBvdeuDnlwAPT2guNhdIoW3IP7GmHh1SMKPLxRf7x8vJy6ZFK3ol2ohgn_-0yP7QQA=", +      data: %{} +    } +  end + +  def notification_factory do +    %Pleroma.Notification{ +      user: build(:user) +    } +  end + +  def scheduled_activity_factory do +    %Pleroma.ScheduledActivity{ +      user: build(:user), +      scheduled_at: NaiveDateTime.add(NaiveDateTime.utc_now(), :timer.minutes(60), :millisecond), +      params: build(:note) |> Map.from_struct() |> Map.get(:data) +    } +  end + +  def registration_factory do +    user = insert(:user) + +    %Pleroma.Registration{ +      user: user, +      provider: "twitter", +      uid: "171799000", +      info: %{ +        "name" => "John Doe", +        "email" => "john@doe.com", +        "nickname" => "johndoe", +        "description" => "My bio" +      } +    } +  end  end diff --git a/test/support/helpers.ex b/test/support/helpers.ex new file mode 100644 index 000000000..6e389ce52 --- /dev/null +++ b/test/support/helpers.ex @@ -0,0 +1,29 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2018 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only + +defmodule Pleroma.Tests.Helpers do +  @moduledoc """ +  Helpers for use in tests. +  """ + +  defmacro __using__(_opts) do +    quote do +      def refresh_record(%{id: id, __struct__: model} = _), +        do: refresh_record(model, %{id: id}) + +      def refresh_record(model, %{id: id} = _) do +        Pleroma.Repo.get_by(model, id: id) +      end + +      # Used for comparing json rendering during tests. +      def render_json(view, template, assigns) do +        assigns = Map.new(assigns) + +        view.render(template, assigns) +        |> Poison.encode!() +        |> Poison.decode!() +      end +    end +  end +end diff --git a/test/support/http_request_mock.ex b/test/support/http_request_mock.ex new file mode 100644 index 000000000..5b355bfe6 --- /dev/null +++ b/test/support/http_request_mock.ex @@ -0,0 +1,791 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2018 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only + +defmodule HttpRequestMock do +  require Logger + +  def request( +        %Tesla.Env{ +          url: url, +          method: method, +          headers: headers, +          query: query, +          body: body +        } = _env +      ) do +    with {:ok, res} <- apply(__MODULE__, method, [url, query, body, headers]) do +      res +    else +      {_, _r} = error -> +        # Logger.warn(r) +        error +    end +  end + +  # GET Requests +  # +  def get(url, query \\ [], body \\ [], headers \\ []) + +  def get("https://osada.macgirvin.com/channel/mike", _, _, _) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: +         File.read!("test/fixtures/httpoison_mock/https___osada.macgirvin.com_channel_mike.json") +     }} +  end + +  def get("https://mastodon.social/users/emelie/statuses/101849165031453009", _, _, _) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/status.emelie.json") +     }} +  end + +  def get("https://mastodon.social/users/emelie", _, _, _) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/emelie.json") +     }} +  end + +  def get( +        "https://mastodon.social/.well-known/webfinger?resource=https://mastodon.social/users/emelie", +        _, +        _, +        _ +      ) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/webfinger_emelie.json") +     }} +  end + +  def get("https://mastodon.social/users/emelie.atom", _, _, _) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/emelie.atom") +     }} +  end + +  def get( +        "https://osada.macgirvin.com/.well-known/webfinger?resource=acct:mike@osada.macgirvin.com", +        _, +        _, +        Accept: "application/xrd+xml,application/jrd+json" +      ) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/mike@osada.macgirvin.com.json") +     }} +  end + +  def get( +        "https://social.heldscal.la/.well-known/webfinger?resource=https://social.heldscal.la/user/29191", +        _, +        _, +        Accept: "application/xrd+xml,application/jrd+json" +      ) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/https___social.heldscal.la_user_29191.xml") +     }} +  end + +  def get("https://pawoo.net/users/pekorino.atom", _, _, _) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/https___pawoo.net_users_pekorino.atom") +     }} +  end + +  def get( +        "https://pawoo.net/.well-known/webfinger?resource=acct:https://pawoo.net/users/pekorino", +        _, +        _, +        Accept: "application/xrd+xml,application/jrd+json" +      ) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/https___pawoo.net_users_pekorino.xml") +     }} +  end + +  def get( +        "https://social.stopwatchingus-heidelberg.de/api/statuses/user_timeline/18330.atom", +        _, +        _, +        _ +      ) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/atarifrosch_feed.xml") +     }} +  end + +  def get( +        "https://social.stopwatchingus-heidelberg.de/.well-known/webfinger?resource=acct:https://social.stopwatchingus-heidelberg.de/user/18330", +        _, +        _, +        Accept: "application/xrd+xml,application/jrd+json" +      ) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/atarifrosch_webfinger.xml") +     }} +  end + +  def get("https://mamot.fr/users/Skruyb.atom", _, _, _) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/https___mamot.fr_users_Skruyb.atom") +     }} +  end + +  def get( +        "https://mamot.fr/.well-known/webfinger?resource=acct:https://mamot.fr/users/Skruyb", +        _, +        _, +        Accept: "application/xrd+xml,application/jrd+json" +      ) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/skruyb@mamot.fr.atom") +     }} +  end + +  def get( +        "https://social.heldscal.la/.well-known/webfinger?resource=nonexistant@social.heldscal.la", +        _, +        _, +        Accept: "application/xrd+xml,application/jrd+json" +      ) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/nonexistant@social.heldscal.la.xml") +     }} +  end + +  def get( +        "https://squeet.me/xrd/?uri=lain@squeet.me", +        _, +        _, +        Accept: "application/xrd+xml,application/jrd+json" +      ) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/lain_squeet.me_webfinger.xml") +     }} +  end + +  def get( +        "https://mst3k.interlinked.me/users/luciferMysticus", +        _, +        _, +        Accept: "application/activity+json" +      ) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/lucifermysticus.json") +     }} +  end + +  def get("https://prismo.news/@mxb", _, _, _) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/https___prismo.news__mxb.json") +     }} +  end + +  def get( +        "https://hubzilla.example.org/channel/kaniini", +        _, +        _, +        Accept: "application/activity+json" +      ) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/kaniini@hubzilla.example.org.json") +     }} +  end + +  def get("https://niu.moe/users/rye", _, _, Accept: "application/activity+json") do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/rye.json") +     }} +  end + +  def get("http://mastodon.example.org/users/admin/statuses/100787282858396771", _, _, _) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: +         File.read!( +           "test/fixtures/httpoison_mock/http___mastodon.example.org_users_admin_status_1234.json" +         ) +     }} +  end + +  def get("https://puckipedia.com/", _, _, Accept: "application/activity+json") do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/puckipedia.com.json") +     }} +  end + +  def get("https://peertube.moe/accounts/7even", _, _, _) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/7even.json") +     }} +  end + +  def get("https://peertube.moe/videos/watch/df5f464b-be8d-46fb-ad81-2d4c2d1630e3", _, _, _) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/peertube.moe-vid.json") +     }} +  end + +  def get("https://baptiste.gelez.xyz/@/BaptisteGelez", _, _, _) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/baptiste.gelex.xyz-user.json") +     }} +  end + +  def get("https://baptiste.gelez.xyz/~/PlumeDevelopment/this-month-in-plume-june-2018/", _, _, _) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/baptiste.gelex.xyz-article.json") +     }} +  end + +  def get("http://mastodon.example.org/users/admin", _, _, Accept: "application/activity+json") do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/admin@mastdon.example.org.json") +     }} +  end + +  def get( +        "http://mastodon.example.org/@admin/99541947525187367", +        _, +        _, +        Accept: "application/activity+json" +      ) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/mastodon-note-object.json") +     }} +  end + +  def get("https://shitposter.club/notice/7369654", _, _, _) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/7369654.html") +     }} +  end + +  def get("https://mstdn.io/users/mayuutann", _, _, Accept: "application/activity+json") do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/mayumayu.json") +     }} +  end + +  def get( +        "https://mstdn.io/users/mayuutann/statuses/99568293732299394", +        _, +        _, +        Accept: "application/activity+json" +      ) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/mayumayupost.json") +     }} +  end + +  def get("https://pleroma.soykaf.com/users/lain/feed.atom", _, _, _) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: +         File.read!( +           "test/fixtures/httpoison_mock/https___pleroma.soykaf.com_users_lain_feed.atom.xml" +         ) +     }} +  end + +  def get(url, _, _, Accept: "application/xrd+xml,application/jrd+json") +      when url in [ +             "https://pleroma.soykaf.com/.well-known/webfinger?resource=acct:https://pleroma.soykaf.com/users/lain", +             "https://pleroma.soykaf.com/.well-known/webfinger?resource=https://pleroma.soykaf.com/users/lain" +           ] do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/https___pleroma.soykaf.com_users_lain.xml") +     }} +  end + +  def get("https://shitposter.club/api/statuses/user_timeline/1.atom", _, _, _) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: +         File.read!( +           "test/fixtures/httpoison_mock/https___shitposter.club_api_statuses_user_timeline_1.atom.xml" +         ) +     }} +  end + +  def get( +        "https://shitposter.club/.well-known/webfinger?resource=https://shitposter.club/user/1", +        _, +        _, +        Accept: "application/xrd+xml,application/jrd+json" +      ) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/https___shitposter.club_user_1.xml") +     }} +  end + +  def get("https://shitposter.club/notice/2827873", _, _, _) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: +         File.read!("test/fixtures/httpoison_mock/https___shitposter.club_notice_2827873.html") +     }} +  end + +  def get("https://shitposter.club/api/statuses/show/2827873.atom", _, _, _) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: +         File.read!( +           "test/fixtures/httpoison_mock/https___shitposter.club_api_statuses_show_2827873.atom.xml" +         ) +     }} +  end + +  def get("https://testing.pleroma.lol/objects/b319022a-4946-44c5-9de9-34801f95507b", _, _, _) do +    {:ok, %Tesla.Env{status: 200}} +  end + +  def get("https://shitposter.club/api/statuses/user_timeline/5381.atom", _, _, _) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/spc_5381.atom") +     }} +  end + +  def get( +        "https://shitposter.club/.well-known/webfinger?resource=https://shitposter.club/user/5381", +        _, +        _, +        Accept: "application/xrd+xml,application/jrd+json" +      ) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/spc_5381_xrd.xml") +     }} +  end + +  def get("http://shitposter.club/.well-known/host-meta", _, _, _) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/shitposter.club_host_meta") +     }} +  end + +  def get("https://shitposter.club/api/statuses/show/7369654.atom", _, _, _) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/7369654.atom") +     }} +  end + +  def get("https://shitposter.club/notice/4027863", _, _, _) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/7369654.html") +     }} +  end + +  def get("https://social.sakamoto.gq/users/eal/feed.atom", _, _, _) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/sakamoto_eal_feed.atom") +     }} +  end + +  def get("http://social.sakamoto.gq/.well-known/host-meta", _, _, _) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/social.sakamoto.gq_host_meta") +     }} +  end + +  def get( +        "https://social.sakamoto.gq/.well-known/webfinger?resource=https://social.sakamoto.gq/users/eal", +        _, +        _, +        Accept: "application/xrd+xml,application/jrd+json" +      ) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/eal_sakamoto.xml") +     }} +  end + +  def get( +        "https://social.sakamoto.gq/objects/0ccc1a2c-66b0-4305-b23a-7f7f2b040056", +        _, +        _, +        Accept: "application/atom+xml" +      ) do +    {:ok, %Tesla.Env{status: 200, body: File.read!("test/fixtures/httpoison_mock/sakamoto.atom")}} +  end + +  def get("http://mastodon.social/.well-known/host-meta", _, _, _) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/mastodon.social_host_meta") +     }} +  end + +  def get( +        "https://mastodon.social/.well-known/webfinger?resource=https://mastodon.social/users/lambadalambda", +        _, +        _, +        Accept: "application/xrd+xml,application/jrd+json" +      ) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: +         File.read!( +           "test/fixtures/httpoison_mock/https___mastodon.social_users_lambadalambda.xml" +         ) +     }} +  end + +  def get("http://gs.example.org/.well-known/host-meta", _, _, _) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/gs.example.org_host_meta") +     }} +  end + +  def get( +        "http://gs.example.org/.well-known/webfinger?resource=http://gs.example.org:4040/index.php/user/1", +        _, +        _, +        Accept: "application/xrd+xml,application/jrd+json" +      ) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: +         File.read!( +           "test/fixtures/httpoison_mock/http___gs.example.org_4040_index.php_user_1.xml" +         ) +     }} +  end + +  def get("http://gs.example.org/index.php/api/statuses/user_timeline/1.atom", _, _, _) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: +         File.read!( +           "test/fixtures/httpoison_mock/http__gs.example.org_index.php_api_statuses_user_timeline_1.atom.xml" +         ) +     }} +  end + +  def get("https://social.heldscal.la/api/statuses/user_timeline/29191.atom", _, _, _) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: +         File.read!( +           "test/fixtures/httpoison_mock/https___social.heldscal.la_api_statuses_user_timeline_29191.atom.xml" +         ) +     }} +  end + +  def get("http://squeet.me/.well-known/host-meta", _, _, _) do +    {:ok, +     %Tesla.Env{status: 200, body: File.read!("test/fixtures/httpoison_mock/squeet.me_host_meta")}} +  end + +  def get( +        "https://squeet.me/xrd?uri=lain@squeet.me", +        _, +        _, +        Accept: "application/xrd+xml,application/jrd+json" +      ) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/lain_squeet.me_webfinger.xml") +     }} +  end + +  def get( +        "https://social.heldscal.la/.well-known/webfinger?resource=shp@social.heldscal.la", +        _, +        _, +        Accept: "application/xrd+xml,application/jrd+json" +      ) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/shp@social.heldscal.la.xml") +     }} +  end + +  def get("http://framatube.org/.well-known/host-meta", _, _, _) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/framatube.org_host_meta") +     }} +  end + +  def get( +        "http://framatube.org/main/xrd?uri=framasoft@framatube.org", +        _, +        _, +        Accept: "application/xrd+xml,application/jrd+json" +      ) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       headers: [{"content-type", "application/json"}], +       body: File.read!("test/fixtures/httpoison_mock/framasoft@framatube.org.json") +     }} +  end + +  def get("http://gnusocial.de/.well-known/host-meta", _, _, _) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/gnusocial.de_host_meta") +     }} +  end + +  def get( +        "http://gnusocial.de/main/xrd?uri=winterdienst@gnusocial.de", +        _, +        _, +        Accept: "application/xrd+xml,application/jrd+json" +      ) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/winterdienst_webfinger.json") +     }} +  end + +  def get("http://status.alpicola.com/.well-known/host-meta", _, _, _) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/status.alpicola.com_host_meta") +     }} +  end + +  def get("http://macgirvin.com/.well-known/host-meta", _, _, _) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/macgirvin.com_host_meta") +     }} +  end + +  def get("http://gerzilla.de/.well-known/host-meta", _, _, _) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/gerzilla.de_host_meta") +     }} +  end + +  def get( +        "https://gerzilla.de/xrd/?uri=kaniini@gerzilla.de", +        _, +        _, +        Accept: "application/xrd+xml,application/jrd+json" +      ) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       headers: [{"content-type", "application/json"}], +       body: File.read!("test/fixtures/httpoison_mock/kaniini@gerzilla.de.json") +     }} +  end + +  def get("https://social.heldscal.la/api/statuses/user_timeline/23211.atom", _, _, _) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: +         File.read!( +           "test/fixtures/httpoison_mock/https___social.heldscal.la_api_statuses_user_timeline_23211.atom.xml" +         ) +     }} +  end + +  def get( +        "https://social.heldscal.la/.well-known/webfinger?resource=https://social.heldscal.la/user/23211", +        _, +        _, +        _ +      ) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/https___social.heldscal.la_user_23211.xml") +     }} +  end + +  def get("http://social.heldscal.la/.well-known/host-meta", _, _, _) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/social.heldscal.la_host_meta") +     }} +  end + +  def get("https://social.heldscal.la/.well-known/host-meta", _, _, _) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: File.read!("test/fixtures/httpoison_mock/social.heldscal.la_host_meta") +     }} +  end + +  def get("https://mastodon.social/users/lambadalambda.atom", _, _, _) do +    {:ok, %Tesla.Env{status: 200, body: File.read!("test/fixtures/lambadalambda.atom")}} +  end + +  def get("https://mastodon.social/users/lambadalambda", _, _, _) do +    {:ok, %Tesla.Env{status: 200, body: File.read!("test/fixtures/lambadalambda.json")}} +  end + +  def get("https://social.heldscal.la/user/23211", _, _, Accept: "application/activity+json") do +    {:ok, Tesla.Mock.json(%{"id" => "https://social.heldscal.la/user/23211"}, status: 200)} +  end + +  def get("http://example.com/ogp", _, _, _) do +    {:ok, %Tesla.Env{status: 200, body: File.read!("test/fixtures/rich_media/ogp.html")}} +  end + +  def get("http://example.com/malformed", _, _, _) do +    {:ok, +     %Tesla.Env{status: 200, body: File.read!("test/fixtures/rich_media/malformed-data.html")}} +  end + +  def get("http://example.com/empty", _, _, _) do +    {:ok, %Tesla.Env{status: 200, body: "hello"}} +  end + +  def get("http://404.site" <> _, _, _, _) do +    {:ok, +     %Tesla.Env{ +       status: 404, +       body: "" +     }} +  end + +  def get(url, query, body, headers) do +    {:error, +     "Not implemented the mock response for get #{inspect(url)}, #{query}, #{inspect(body)}, #{ +       inspect(headers) +     }"} +  end + +  # POST Requests +  # + +  def post(url, query \\ [], body \\ [], headers \\ []) + +  def post("http://example.org/needs_refresh", _, _, _) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: "" +     }} +  end + +  def post("http://200.site" <> _, _, _, _) do +    {:ok, +     %Tesla.Env{ +       status: 200, +       body: "" +     }} +  end + +  def post("http://connrefused.site" <> _, _, _, _) do +    {:error, :connrefused} +  end + +  def post("http://404.site" <> _, _, _, _) do +    {:ok, +     %Tesla.Env{ +       status: 404, +       body: "" +     }} +  end + +  def post(url, _query, _body, _headers) do +    {:error, "Not implemented the mock response for post #{inspect(url)}"} +  end +end diff --git a/test/support/httpoison_mock.ex b/test/support/httpoison_mock.ex deleted file mode 100644 index e7344500f..000000000 --- a/test/support/httpoison_mock.ex +++ /dev/null @@ -1,883 +0,0 @@ -defmodule HTTPoisonMock do -  alias HTTPoison.Response - -  def process_request_options(options), do: options - -  def get(url, body \\ [], headers \\ []) - -  def get("https://prismo.news/@mxb", _, _) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/https___prismo.news__mxb.json") -     }} -  end - -  def get("https://osada.macgirvin.com/channel/mike", _, _) do -    {:ok, -     %Response{ -       status_code: 200, -       body: -         File.read!("test/fixtures/httpoison_mock/https___osada.macgirvin.com_channel_mike.json") -     }} -  end - -  def get( -        "https://osada.macgirvin.com/.well-known/webfinger?resource=acct:mike@osada.macgirvin.com", -        _, -        _ -      ) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/mike@osada.macgirvin.com.json") -     }} -  end - -  def get("https://info.pleroma.site/activity.json", _, _) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/https__info.pleroma.site_activity.json") -     }} -  end - -  def get("https://info.pleroma.site/activity2.json", _, _) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/https__info.pleroma.site_activity2.json") -     }} -  end - -  def get("https://info.pleroma.site/activity3.json", _, _) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/https__info.pleroma.site_activity3.json") -     }} -  end - -  def get("https://info.pleroma.site/activity4.json", _, _) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/https__info.pleroma.site_activity4.json") -     }} -  end - -  def get("https://info.pleroma.site/actor.json", _, _) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/https___info.pleroma.site_actor.json") -     }} -  end - -  def get("https://puckipedia.com/", [Accept: "application/activity+json"], _) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/puckipedia.com.json") -     }} -  end - -  def get( -        "https://gerzilla.de/.well-known/webfinger?resource=acct:kaniini@gerzilla.de", -        [Accept: "application/xrd+xml,application/jrd+json"], -        follow_redirect: true -      ) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/kaniini@gerzilla.de.json") -     }} -  end - -  def get( -        "https://framatube.org/.well-known/webfinger?resource=acct:framasoft@framatube.org", -        [Accept: "application/xrd+xml,application/jrd+json"], -        follow_redirect: true -      ) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/framasoft@framatube.org.json") -     }} -  end - -  def get( -        "https://gnusocial.de/.well-known/webfinger?resource=acct:winterdienst@gnusocial.de", -        [Accept: "application/xrd+xml,application/jrd+json"], -        follow_redirect: true -      ) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/winterdienst_webfinger.json") -     }} -  end - -  def get( -        "https://social.heldscal.la/.well-known/webfinger", -        [Accept: "application/xrd+xml,application/jrd+json"], -        params: [resource: "nonexistant@social.heldscal.la"], -        follow_redirect: true -      ) do -    {:ok, -     %Response{ -       status_code: 500, -       body: File.read!("test/fixtures/httpoison_mock/nonexistant@social.heldscal.la.xml") -     }} -  end - -  def get( -        "https://social.heldscal.la/.well-known/webfinger?resource=shp@social.heldscal.la", -        [Accept: "application/xrd+xml,application/jrd+json"], -        follow_redirect: true -      ) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/shp@social.heldscal.la.xml") -     }} -  end - -  def get( -        "https://social.heldscal.la/.well-known/webfinger", -        [Accept: "application/xrd+xml,application/jrd+json"], -        params: [resource: "shp@social.heldscal.la"], -        follow_redirect: true -      ) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/shp@social.heldscal.la.xml") -     }} -  end - -  def get( -        "https://social.heldscal.la/.well-known/webfinger", -        [Accept: "application/xrd+xml,application/jrd+json"], -        params: [resource: "https://social.heldscal.la/user/23211"], -        follow_redirect: true -      ) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/https___social.heldscal.la_user_23211.xml") -     }} -  end - -  def get( -        "https://social.heldscal.la/.well-known/webfinger?resource=https://social.heldscal.la/user/23211", -        [Accept: "application/xrd+xml,application/jrd+json"], -        follow_redirect: true -      ) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/https___social.heldscal.la_user_23211.xml") -     }} -  end - -  def get( -        "https://social.heldscal.la/.well-known/webfinger", -        [Accept: "application/xrd+xml,application/jrd+json"], -        params: [resource: "https://social.heldscal.la/user/29191"], -        follow_redirect: true -      ) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/https___social.heldscal.la_user_29191.xml") -     }} -  end - -  def get( -        "https://social.heldscal.la/.well-known/webfinger?resource=https://social.heldscal.la/user/29191", -        [Accept: "application/xrd+xml,application/jrd+json"], -        follow_redirect: true -      ) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/https___social.heldscal.la_user_29191.xml") -     }} -  end - -  def get( -        "https://mastodon.social/.well-known/webfinger", -        [Accept: "application/xrd+xml,application/jrd+json"], -        params: [resource: "https://mastodon.social/users/lambadalambda"], -        follow_redirect: true -      ) do -    {:ok, -     %Response{ -       status_code: 200, -       body: -         File.read!( -           "test/fixtures/httpoison_mock/https___mastodon.social_users_lambadalambda.xml" -         ) -     }} -  end - -  def get( -        "https://mastodon.social/.well-known/webfinger?resource=https://mastodon.social/users/lambadalambda", -        [Accept: "application/xrd+xml,application/jrd+json"], -        follow_redirect: true -      ) do -    {:ok, -     %Response{ -       status_code: 200, -       body: -         File.read!( -           "test/fixtures/httpoison_mock/https___mastodon.social_users_lambadalambda.xml" -         ) -     }} -  end - -  def get( -        "https://shitposter.club/.well-known/webfinger", -        [Accept: "application/xrd+xml,application/jrd+json"], -        params: [resource: "https://shitposter.club/user/1"], -        follow_redirect: true -      ) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/https___shitposter.club_user_1.xml") -     }} -  end - -  def get( -        "https://shitposter.club/.well-known/webfinger?resource=https://shitposter.club/user/1", -        [Accept: "application/xrd+xml,application/jrd+json"], -        follow_redirect: true -      ) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/https___shitposter.club_user_1.xml") -     }} -  end - -  def get( -        "https://shitposter.club/.well-known/webfinger?resource=https://shitposter.club/user/5381", -        [Accept: "application/xrd+xml,application/jrd+json"], -        follow_redirect: true -      ) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/spc_5381_xrd.xml") -     }} -  end - -  def get( -        "http://gs.example.org/.well-known/webfinger", -        [Accept: "application/xrd+xml,application/jrd+json"], -        params: [resource: "http://gs.example.org:4040/index.php/user/1"], -        follow_redirect: true -      ) do -    {:ok, -     %Response{ -       status_code: 200, -       body: -         File.read!( -           "test/fixtures/httpoison_mock/http___gs.example.org_4040_index.php_user_1.xml" -         ) -     }} -  end - -  def get( -        "http://gs.example.org/.well-known/webfinger?resource=http://gs.example.org:4040/index.php/user/1", -        [Accept: "application/xrd+xml,application/jrd+json"], -        follow_redirect: true -      ) do -    {:ok, -     %Response{ -       status_code: 200, -       body: -         File.read!( -           "test/fixtures/httpoison_mock/http___gs.example.org_4040_index.php_user_1.xml" -         ) -     }} -  end - -  def get( -        "https://social.stopwatchingus-heidelberg.de/.well-known/webfinger?resource=https://social.stopwatchingus-heidelberg.de/user/18330", -        [Accept: "application/xrd+xml,application/jrd+json"], -        follow_redirect: true -      ) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/atarifrosch_webfinger.xml") -     }} -  end - -  def get( -        "https://pleroma.soykaf.com/.well-known/webfinger", -        [Accept: "application/xrd+xml,application/jrd+json"], -        params: [resource: "https://pleroma.soykaf.com/users/lain"], -        follow_redirect: true -      ) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/https___pleroma.soykaf.com_users_lain.xml") -     }} -  end - -  def get( -        "https://pleroma.soykaf.com/.well-known/webfinger?resource=https://pleroma.soykaf.com/users/lain", -        [Accept: "application/xrd+xml,application/jrd+json"], -        follow_redirect: true -      ) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/https___pleroma.soykaf.com_users_lain.xml") -     }} -  end - -  def get("https://social.heldscal.la/api/statuses/user_timeline/29191.atom", _body, _headers) do -    {:ok, -     %Response{ -       status_code: 200, -       body: -         File.read!( -           "test/fixtures/httpoison_mock/https___social.heldscal.la_api_statuses_user_timeline_29191.atom.xml" -         ) -     }} -  end - -  def get("https://shitposter.club/api/statuses/user_timeline/5381.atom", _body, _headers) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/spc_5381.atom") -     }} -  end - -  def get("https://social.heldscal.la/api/statuses/user_timeline/23211.atom", _body, _headers) do -    {:ok, -     %Response{ -       status_code: 200, -       body: -         File.read!( -           "test/fixtures/httpoison_mock/https___social.heldscal.la_api_statuses_user_timeline_23211.atom.xml" -         ) -     }} -  end - -  def get("https://mastodon.social/users/lambadalambda.atom", _body, _headers) do -    {:ok, -     %Response{ -       status_code: 200, -       body: -         File.read!( -           "test/fixtures/httpoison_mock/https___mastodon.social_users_lambadalambda.atom" -         ) -     }} -  end - -  def get( -        "https://social.stopwatchingus-heidelberg.de/api/statuses/user_timeline/18330.atom", -        _body, -        _headers -      ) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/atarifrosch_feed.xml") -     }} -  end - -  def get("https://pleroma.soykaf.com/users/lain/feed.atom", _body, _headers) do -    {:ok, -     %Response{ -       status_code: 200, -       body: -         File.read!( -           "test/fixtures/httpoison_mock/https___pleroma.soykaf.com_users_lain_feed.atom.xml" -         ) -     }} -  end - -  def get("https://social.sakamoto.gq/users/eal/feed.atom", _body, _headers) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/sakamoto_eal_feed.atom") -     }} -  end - -  def get("http://gs.example.org/index.php/api/statuses/user_timeline/1.atom", _body, _headers) do -    {:ok, -     %Response{ -       status_code: 200, -       body: -         File.read!( -           "test/fixtures/httpoison_mock/http__gs.example.org_index.php_api_statuses_user_timeline_1.atom.xml" -         ) -     }} -  end - -  def get("https://shitposter.club/notice/2827873", _body, _headers) do -    {:ok, -     %Response{ -       status_code: 200, -       body: -         File.read!("test/fixtures/httpoison_mock/https___shitposter.club_notice_2827873.html") -     }} -  end - -  def get("https://shitposter.club/api/statuses/show/2827873.atom", _body, _headers) do -    {:ok, -     %Response{ -       status_code: 200, -       body: -         File.read!( -           "test/fixtures/httpoison_mock/https___shitposter.club_api_statuses_show_2827873.atom.xml" -         ) -     }} -  end - -  def get("https://shitposter.club/api/statuses/user_timeline/1.atom", _body, _headers) do -    {:ok, -     %Response{ -       status_code: 200, -       body: -         File.read!( -           "test/fixtures/httpoison_mock/https___shitposter.club_api_statuses_user_timeline_1.atom.xml" -         ) -     }} -  end - -  def post( -        "https://social.heldscal.la/main/push/hub", -        {:form, _data}, -        "Content-type": "application/x-www-form-urlencoded" -      ) do -    {:ok, -     %Response{ -       status_code: 202 -     }} -  end - -  def get("http://mastodon.example.org/users/admin/statuses/100787282858396771", _, _) do -    {:ok, -     %Response{ -       status_code: 200, -       body: -         File.read!( -           "test/fixtures/httpoison_mock/http___mastodon.example.org_users_admin_status_1234.json" -         ) -     }} -  end - -  def get( -        "https://pawoo.net/.well-known/webfinger", -        [Accept: "application/xrd+xml,application/jrd+json"], -        params: [resource: "https://pawoo.net/users/pekorino"], -        follow_redirect: true -      ) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/https___pawoo.net_users_pekorino.xml") -     }} -  end - -  def get( -        "https://pawoo.net/.well-known/webfinger?resource=https://pawoo.net/users/pekorino", -        [Accept: "application/xrd+xml,application/jrd+json"], -        follow_redirect: true -      ) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/https___pawoo.net_users_pekorino.xml") -     }} -  end - -  def get("https://pawoo.net/users/pekorino.atom", _, _) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/https___pawoo.net_users_pekorino.atom") -     }} -  end - -  def get( -        "https://mamot.fr/.well-known/webfinger", -        [Accept: "application/xrd+xml,application/jrd+json"], -        params: [resource: "https://mamot.fr/users/Skruyb"], -        follow_redirect: true -      ) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/skruyb@mamot.fr.atom") -     }} -  end - -  def get( -        "https://mamot.fr/.well-known/webfinger?resource=https://mamot.fr/users/Skruyb", -        [Accept: "application/xrd+xml,application/jrd+json"], -        follow_redirect: true -      ) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/skruyb@mamot.fr.atom") -     }} -  end - -  def get( -        "https://social.sakamoto.gq/.well-known/webfinger", -        [Accept: "application/xrd+xml,application/jrd+json"], -        params: [resource: "https://social.sakamoto.gq/users/eal"], -        follow_redirect: true -      ) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/eal_sakamoto.xml") -     }} -  end - -  def get( -        "https://social.sakamoto.gq/.well-known/webfinger?resource=https://social.sakamoto.gq/users/eal", -        [Accept: "application/xrd+xml,application/jrd+json"], -        follow_redirect: true -      ) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/eal_sakamoto.xml") -     }} -  end - -  def get( -        "https://pleroma.soykaf.com/.well-known/webfinger?resource=https://pleroma.soykaf.com/users/shp", -        [Accept: "application/xrd+xml,application/jrd+json"], -        follow_redirect: true -      ) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/shp@pleroma.soykaf.com.webfigner") -     }} -  end - -  def get( -        "https://squeet.me/xrd/?uri=lain@squeet.me", -        [Accept: "application/xrd+xml,application/jrd+json"], -        follow_redirect: true -      ) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/lain_squeet.me_webfinger.xml") -     }} -  end - -  def get("https://mamot.fr/users/Skruyb.atom", _, _) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/https___mamot.fr_users_Skruyb.atom") -     }} -  end - -  def get( -        "https://social.sakamoto.gq/objects/0ccc1a2c-66b0-4305-b23a-7f7f2b040056", -        [Accept: "application/atom+xml"], -        _ -      ) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/sakamoto.atom") -     }} -  end - -  def get("https://pleroma.soykaf.com/users/shp/feed.atom", _, _) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/shp@pleroma.soykaf.com.feed") -     }} -  end - -  def get("http://social.heldscal.la/.well-known/host-meta", [], follow_redirect: true) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/social.heldscal.la_host_meta") -     }} -  end - -  def get("http://status.alpicola.com/.well-known/host-meta", [], follow_redirect: true) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/status.alpicola.com_host_meta") -     }} -  end - -  def get("http://macgirvin.com/.well-known/host-meta", [], follow_redirect: true) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/macgirvin.com_host_meta") -     }} -  end - -  def get("http://mastodon.social/.well-known/host-meta", [], follow_redirect: true) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/mastodon.social_host_meta") -     }} -  end - -  def get("http://shitposter.club/.well-known/host-meta", [], follow_redirect: true) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/shitposter.club_host_meta") -     }} -  end - -  def get("http://pleroma.soykaf.com/.well-known/host-meta", [], follow_redirect: true) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/pleroma.soykaf.com_host_meta") -     }} -  end - -  def get("http://social.sakamoto.gq/.well-known/host-meta", [], follow_redirect: true) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/social.sakamoto.gq_host_meta") -     }} -  end - -  def get("http://gs.example.org/.well-known/host-meta", [], follow_redirect: true) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/gs.example.org_host_meta") -     }} -  end - -  def get("http://pawoo.net/.well-known/host-meta", [], follow_redirect: true) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/pawoo.net_host_meta") -     }} -  end - -  def get("http://mamot.fr/.well-known/host-meta", [], follow_redirect: true) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/mamot.fr_host_meta") -     }} -  end - -  def get("http://mastodon.xyz/.well-known/host-meta", [], follow_redirect: true) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/mastodon.xyz_host_meta") -     }} -  end - -  def get("http://social.wxcafe.net/.well-known/host-meta", [], follow_redirect: true) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/social.wxcafe.net_host_meta") -     }} -  end - -  def get("http://squeet.me/.well-known/host-meta", [], follow_redirect: true) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/squeet.me_host_meta") -     }} -  end - -  def get( -        "http://social.stopwatchingus-heidelberg.de/.well-known/host-meta", -        [], -        follow_redirect: true -      ) do -    {:ok, -     %Response{ -       status_code: 200, -       body: -         File.read!("test/fixtures/httpoison_mock/social.stopwatchingus-heidelberg.de_host_meta") -     }} -  end - -  def get("http://mastodon.example.org/users/admin", [Accept: "application/activity+json"], _) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/admin@mastdon.example.org.json") -     }} -  end - -  def get( -        "https://hubzilla.example.org/channel/kaniini", -        [Accept: "application/activity+json"], -        _ -      ) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/kaniini@hubzilla.example.org.json") -     }} -  end - -  def get("https://masto.quad.moe/users/_HellPie", [Accept: "application/activity+json"], _) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/hellpie.json") -     }} -  end - -  def get("https://niu.moe/users/rye", [Accept: "application/activity+json"], _) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/rye.json") -     }} -  end - -  def get("https://n1u.moe/users/rye", [Accept: "application/activity+json"], _) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/rye.json") -     }} -  end - -  def get( -        "https://mst3k.interlinked.me/users/luciferMysticus", -        [Accept: "application/activity+json"], -        _ -      ) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/lucifermysticus.json") -     }} -  end - -  def get("https://mstdn.io/users/mayuutann", [Accept: "application/activity+json"], _) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/mayumayu.json") -     }} -  end - -  def get( -        "http://mastodon.example.org/@admin/99541947525187367", -        [Accept: "application/activity+json"], -        _ -      ) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/mastodon-note-object.json") -     }} -  end - -  def get( -        "https://mstdn.io/users/mayuutann/statuses/99568293732299394", -        [Accept: "application/activity+json"], -        _ -      ) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/mayumayupost.json") -     }} -  end - -  def get("https://shitposter.club/notice/7369654", _, _) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/7369654.html") -     }} -  end - -  def get("https://shitposter.club/api/statuses/show/7369654.atom", _body, _headers) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/7369654.atom") -     }} -  end - -  def get("https://baptiste.gelez.xyz/~/PlumeDevelopment/this-month-in-plume-june-2018/", _, _) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/baptiste.gelex.xyz-article.json") -     }} -  end - -  def get("https://baptiste.gelez.xyz/@/BaptisteGelez", _, _) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/baptiste.gelex.xyz-user.json") -     }} -  end - -  def get("https://peertube.moe/videos/watch/df5f464b-be8d-46fb-ad81-2d4c2d1630e3", _, _) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/peertube.moe-vid.json") -     }} -  end - -  def get("https://peertube.moe/accounts/7even", _, _) do -    {:ok, -     %Response{ -       status_code: 200, -       body: File.read!("test/fixtures/httpoison_mock/7even.json") -     }} -  end - -  def get(url, body, headers) do -    {:error, -     "Not implemented the mock response for get #{inspect(url)}, #{inspect(body)}, #{ -       inspect(headers) -     }"} -  end - -  def post(url, _body, _headers) do -    {:error, "Not implemented the mock response for post #{inspect(url)}"} -  end - -  def post(url, _body, _headers, _options) do -    {:error, "Not implemented the mock response for post #{inspect(url)}"} -  end -end diff --git a/test/support/ostatus_mock.ex b/test/support/ostatus_mock.ex index 36865ae02..9c0f2f323 100644 --- a/test/support/ostatus_mock.ex +++ b/test/support/ostatus_mock.ex @@ -1,3 +1,7 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2018 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only +  defmodule Pleroma.Web.OStatusMock do    import Pleroma.Factory diff --git a/test/support/web_push_http_client_mock.ex b/test/support/web_push_http_client_mock.ex new file mode 100644 index 000000000..d8accd21c --- /dev/null +++ b/test/support/web_push_http_client_mock.ex @@ -0,0 +1,23 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2018 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only + +defmodule Pleroma.Web.WebPushHttpClientMock do +  def get(url, headers \\ [], options \\ []) do +    { +      res, +      %Tesla.Env{status: status} +    } = Pleroma.HTTP.request(:get, url, "", headers, options) + +    {res, %{status_code: status}} +  end + +  def post(url, body, headers \\ [], options \\ []) do +    { +      res, +      %Tesla.Env{status: status} +    } = Pleroma.HTTP.request(:post, url, body, headers, options) + +    {res, %{status_code: status}} +  end +end diff --git a/test/support/websocket_client.ex b/test/support/websocket_client.ex new file mode 100644 index 000000000..121231452 --- /dev/null +++ b/test/support/websocket_client.ex @@ -0,0 +1,62 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2018 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only + +defmodule Pleroma.Integration.WebsocketClient do +  # https://github.com/phoenixframework/phoenix/blob/master/test/support/websocket_client.exs + +  @doc """ +  Starts the WebSocket server for given ws URL. Received Socket.Message's +  are forwarded to the sender pid +  """ +  def start_link(sender, url, headers \\ []) do +    :crypto.start() +    :ssl.start() + +    :websocket_client.start_link( +      String.to_charlist(url), +      __MODULE__, +      [sender], +      extra_headers: headers +    ) +  end + +  @doc """ +  Closes the socket +  """ +  def close(socket) do +    send(socket, :close) +  end + +  @doc """ +  Sends a low-level text message to the client. +  """ +  def send_text(server_pid, msg) do +    send(server_pid, {:text, msg}) +  end + +  @doc false +  def init([sender], _conn_state) do +    {:ok, %{sender: sender}} +  end + +  @doc false +  def websocket_handle(frame, _conn_state, state) do +    send(state.sender, frame) +    {:ok, state} +  end + +  @doc false +  def websocket_info({:text, msg}, _conn_state, state) do +    {:reply, {:text, msg}, state} +  end + +  def websocket_info(:close, _conn_state, _state) do +    {:close, <<>>, "done"} +  end + +  @doc false +  def websocket_terminate(_reason, _conn_state, _state) do +    :ok +  end +end diff --git a/test/support/websub_mock.ex b/test/support/websub_mock.ex new file mode 100644 index 000000000..e3d5a5b16 --- /dev/null +++ b/test/support/websub_mock.ex @@ -0,0 +1,9 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2018 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only + +defmodule Pleroma.Web.WebsubMock do +  def verify(sub) do +    {:ok, sub} +  end +end | 
