diff options
Diffstat (limited to 'test')
33 files changed, 1093 insertions, 1037 deletions
| diff --git a/test/fixtures/httpoison_mock/framatube.org_host_meta b/test/fixtures/httpoison_mock/framatube.org_host_meta new file mode 100644 index 000000000..91516ff6d --- /dev/null +++ b/test/fixtures/httpoison_mock/framatube.org_host_meta @@ -0,0 +1,2 @@ +<?xml version="1.0" encoding="UTF-8"?> +<XRD xmlns="http://docs.oasis-open.org/ns/xri/xrd-1.0"><hm:Host xmlns:hm="http://host-meta.net/xrd/1.0">framatube.org</hm:Host><Link rel="lrdd" template="http://framatube.org/main/xrd?uri={uri}"><Title>Resource Descriptor</Title></Link></XRD> diff --git a/test/fixtures/httpoison_mock/gerzilla.de_host_meta b/test/fixtures/httpoison_mock/gerzilla.de_host_meta new file mode 100644 index 000000000..fae8f37eb --- /dev/null +++ b/test/fixtures/httpoison_mock/gerzilla.de_host_meta @@ -0,0 +1,10 @@ +<?xml version='1.0' encoding='UTF-8'?><XRD xmlns='http://docs.oasis-open.org/ns/xri/xrd-1.0' +     xmlns:hm='http://host-meta.net/xrd/1.0'> +  +    <hm:Host>gerzilla.de</hm:Host> +  +    <Link rel='lrdd' type="application/xrd+xml" template='https://gerzilla.de/xrd/?uri={uri}' /> +	<Link rel="http://oexchange.org/spec/0.8/rel/resident-target" type="application/xrd+xml"  +        href="https://gerzilla.de/oexchange/xrd" /> + +</XRD> diff --git a/test/fixtures/httpoison_mock/gnusocial.de_host_meta b/test/fixtures/httpoison_mock/gnusocial.de_host_meta new file mode 100644 index 000000000..a4affb102 --- /dev/null +++ b/test/fixtures/httpoison_mock/gnusocial.de_host_meta @@ -0,0 +1,2 @@ +<?xml version="1.0" encoding="UTF-8"?> +<XRD xmlns="http://docs.oasis-open.org/ns/xri/xrd-1.0"><hm:Host xmlns:hm="http://host-meta.net/xrd/1.0">gnusocial.de</hm:Host><Link rel="lrdd" template="http://gnusocial.de/main/xrd?uri={uri}"><Title>Resource Descriptor</Title></Link></XRD> diff --git a/test/formatter_test.exs b/test/formatter_test.exs index 13084baa7..5d745510f 100644 --- a/test/formatter_test.exs +++ b/test/formatter_test.exs @@ -5,6 +5,11 @@ defmodule Pleroma.FormatterTest do    import Pleroma.Factory +  setup_all do +    Tesla.Mock.mock_global(fn env -> apply(HttpRequestMock, :request, [env]) end) +    :ok +  end +    describe ".add_hashtag_links" do      test "turns hashtags into links" do        text = "I love #cofe and #2hu" @@ -110,7 +115,7 @@ defmodule Pleroma.FormatterTest do        archaeme =          insert(:user, %{            nickname: "archaeme", -          info: %{"source_data" => %{"url" => "https://archeme/@archaeme"}} +          info: %Pleroma.User.Info{source_data: %{"url" => "https://archeme/@archaeme"}}          })        archaeme_remote = insert(:user, %{nickname: "archaeme@archae.me"}) diff --git a/test/http_test.exs b/test/http_test.exs new file mode 100644 index 000000000..62f3ccb30 --- /dev/null +++ b/test/http_test.exs @@ -0,0 +1,55 @@ +defmodule Pleroma.HTTPTest do +  use Pleroma.DataCase +  import Tesla.Mock + +  setup do +    mock(fn +      %{ +        method: :get, +        url: "http://example.com/hello", +        headers: [{"content-type", "application/json"}] +      } -> +        json(%{"my" => "data"}) + +      %{method: :get, url: "http://example.com/hello"} -> +        %Tesla.Env{status: 200, body: "hello"} + +      %{method: :post, url: "http://example.com/world"} -> +        %Tesla.Env{status: 200, body: "world"} +    end) + +    :ok +  end + +  describe "get/1" do +    test "returns successfully result" do +      assert Pleroma.HTTP.get("http://example.com/hello") == { +               :ok, +               %Tesla.Env{status: 200, body: "hello"} +             } +    end +  end + +  describe "get/2 (with headers)" do +    test "returns successfully result for json content-type" do +      assert Pleroma.HTTP.get("http://example.com/hello", [{"content-type", "application/json"}]) == +               { +                 :ok, +                 %Tesla.Env{ +                   status: 200, +                   body: "{\"my\":\"data\"}", +                   headers: [{"content-type", "application/json"}] +                 } +               } +    end +  end + +  describe "post/2" do +    test "returns successfully result" do +      assert Pleroma.HTTP.post("http://example.com/world", "") == { +               :ok, +               %Tesla.Env{status: 200, body: "world"} +             } +    end +  end +end diff --git a/test/plugs/user_enabled_plug_test.exs b/test/plugs/user_enabled_plug_test.exs index ee4f72ccf..eeb167933 100644 --- a/test/plugs/user_enabled_plug_test.exs +++ b/test/plugs/user_enabled_plug_test.exs @@ -13,7 +13,7 @@ defmodule Pleroma.Plugs.UserEnabledPlugTest do    end    test "with a user that is deactivated, it removes that user", %{conn: conn} do -    user = insert(:user, info: %{"deactivated" => true}) +    user = insert(:user, info: %{deactivated: true})      conn =        conn diff --git a/test/plugs/user_is_admin_plug_test.exs b/test/plugs/user_is_admin_plug_test.exs index ddf9eb139..031b2f466 100644 --- a/test/plugs/user_is_admin_plug_test.exs +++ b/test/plugs/user_is_admin_plug_test.exs @@ -5,7 +5,7 @@ defmodule Pleroma.Plugs.UserIsAdminPlugTest do    import Pleroma.Factory    test "accepts a user that is admin", %{conn: conn} do -    user = insert(:user, info: %{"is_admin" => true}) +    user = insert(:user, info: %{is_admin: true})      conn =        build_conn() diff --git a/test/support/factory.ex b/test/support/factory.ex index 4f5060abf..2889d8977 100644 --- a/test/support/factory.ex +++ b/test/support/factory.ex @@ -7,7 +7,8 @@ defmodule Pleroma.Factory do        email: sequence(:email, &"user#{&1}@example.com"),        nickname: sequence(:nickname, &"nick#{&1}"),        password_hash: Comeonin.Pbkdf2.hashpwsalt("test"), -      bio: sequence(:bio, &"Tester Number #{&1}") +      bio: sequence(:bio, &"Tester Number #{&1}"), +      info: %{}      }      %{ diff --git a/test/support/http_request_mock.ex b/test/support/http_request_mock.ex new file mode 100644 index 000000000..391342ad7 --- /dev/null +++ b/test/support/http_request_mock.ex @@ -0,0 +1,675 @@ +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://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://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(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(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/user_test.exs b/test/user_test.exs index 231f1d94d..3d2f7f4e0 100644 --- a/test/user_test.exs +++ b/test/user_test.exs @@ -9,6 +9,11 @@ defmodule Pleroma.UserTest do    import Pleroma.Factory    import Ecto.Query +  setup_all do +    Tesla.Mock.mock_global(fn env -> apply(HttpRequestMock, :request, [env]) end) +    :ok +  end +    test "ap_id returns the activity pub id for the user" do      user = UserBuilder.build() @@ -34,14 +39,14 @@ defmodule Pleroma.UserTest do      user = Repo.get(User, user.id)      followed = User.get_by_ap_id(followed.ap_id) -    assert followed.info["follower_count"] == 1 +    assert followed.info.follower_count == 1      assert User.ap_followers(followed) in user.following    end    test "can't follow a deactivated users" do      user = insert(:user) -    followed = insert(:user, info: %{"deactivated" => true}) +    followed = insert(:user, info: %{deactivated: true})      {:error, _} = User.follow(user, followed)    end @@ -56,8 +61,8 @@ defmodule Pleroma.UserTest do    end    test "local users do not automatically follow local locked accounts" do -    follower = insert(:user, info: %{"locked" => true}) -    followed = insert(:user, info: %{"locked" => true}) +    follower = insert(:user, info: %{locked: true}) +    followed = insert(:user, info: %{locked: true})      {:ok, follower} = User.maybe_direct_follow(follower, followed) @@ -144,6 +149,18 @@ defmodule Pleroma.UserTest do        assert changeset.changes.follower_address == "#{changeset.changes.ap_id}/followers"      end + +    test "it ensures info is not nil" do +      changeset = User.register_changeset(%User{}, @full_user_data) + +      assert changeset.valid? + +      {:ok, user} = +        changeset +        |> Repo.insert() + +      refute is_nil(user.info) +    end    end    describe "fetching a user from nickname or trying to build one" do @@ -185,12 +202,14 @@ defmodule Pleroma.UserTest do            local: false,            nickname: "admin@mastodon.example.org",            ap_id: "http://mastodon.example.org/users/admin", -          last_refreshed_at: a_week_ago +          last_refreshed_at: a_week_ago, +          info: %{}          )        assert orig_user.last_refreshed_at == a_week_ago        user = User.get_or_fetch_by_ap_id("http://mastodon.example.org/users/admin") +      assert user.info.source_data["endpoints"]        refute user.last_refreshed_at == orig_user.last_refreshed_at      end @@ -311,45 +330,45 @@ defmodule Pleroma.UserTest do        user = User.get_by_ap_id(note.data["actor"]) -      assert user.info["note_count"] == nil +      assert user.info.note_count == 0        {:ok, user} = User.update_note_count(user) -      assert user.info["note_count"] == 1 +      assert user.info.note_count == 1      end      test "it increases the info->note_count property" do        note = insert(:note)        user = User.get_by_ap_id(note.data["actor"]) -      assert user.info["note_count"] == nil +      assert user.info.note_count == 0        {:ok, user} = User.increase_note_count(user) -      assert user.info["note_count"] == 1 +      assert user.info.note_count == 1        {:ok, user} = User.increase_note_count(user) -      assert user.info["note_count"] == 2 +      assert user.info.note_count == 2      end      test "it decreases the info->note_count property" do        note = insert(:note)        user = User.get_by_ap_id(note.data["actor"]) -      assert user.info["note_count"] == nil +      assert user.info.note_count == 0        {:ok, user} = User.increase_note_count(user) -      assert user.info["note_count"] == 1 +      assert user.info.note_count == 1        {:ok, user} = User.decrease_note_count(user) -      assert user.info["note_count"] == 0 +      assert user.info.note_count == 0        {:ok, user} = User.decrease_note_count(user) -      assert user.info["note_count"] == 0 +      assert user.info.note_count == 0      end      test "it sets the info->follower_count property" do @@ -358,11 +377,11 @@ defmodule Pleroma.UserTest do        User.follow(follower, user) -      assert user.info["follower_count"] == nil +      assert user.info.follower_count == 0        {:ok, user} = User.update_follower_count(user) -      assert user.info["follower_count"] == 1 +      assert user.info.follower_count == 1      end    end @@ -489,11 +508,11 @@ defmodule Pleroma.UserTest do    test ".deactivate can de-activate then re-activate a user" do      user = insert(:user) -    assert false == !!user.info["deactivated"] +    assert false == user.info.deactivated      {:ok, user} = User.deactivate(user) -    assert true == user.info["deactivated"] +    assert true == user.info.deactivated      {:ok, user} = User.deactivate(user, false) -    assert false == !!user.info["deactivated"] +    assert false == user.info.deactivated    end    test ".delete deactivates a user, all follow relationships and all create activities" do @@ -517,7 +536,7 @@ defmodule Pleroma.UserTest do      follower = Repo.get(User, follower.id)      user = Repo.get(User, user.id) -    assert user.info["deactivated"] +    assert user.info.deactivated      refute User.following?(user, followed)      refute User.following?(followed, follower) @@ -546,7 +565,7 @@ defmodule Pleroma.UserTest do      end      test "html_filter_policy returns TwitterText scrubber when rich-text is disabled" do -      user = insert(:user, %{info: %{"no_rich_text" => true}}) +      user = insert(:user, %{info: %{no_rich_text: true}})        assert Pleroma.HTML.Scrubber.TwitterText == User.html_filter_policy(user)      end diff --git a/test/web/activity_pub/activity_pub_controller_test.exs b/test/web/activity_pub/activity_pub_controller_test.exs index 1c24b348c..980f43553 100644 --- a/test/web/activity_pub/activity_pub_controller_test.exs +++ b/test/web/activity_pub/activity_pub_controller_test.exs @@ -5,6 +5,11 @@ defmodule Pleroma.Web.ActivityPub.ActivityPubControllerTest do    alias Pleroma.{Repo, User}    alias Pleroma.Activity +  setup_all do +    Tesla.Mock.mock_global(fn env -> apply(HttpRequestMock, :request, [env]) end) +    :ok +  end +    describe "/relay" do      test "with the relay active, it returns the relay user", %{conn: conn} do        res = diff --git a/test/web/activity_pub/activity_pub_test.exs b/test/web/activity_pub/activity_pub_test.exs index 35c381ac3..90f11ecd4 100644 --- a/test/web/activity_pub/activity_pub_test.exs +++ b/test/web/activity_pub/activity_pub_test.exs @@ -7,6 +7,12 @@ defmodule Pleroma.Web.ActivityPub.ActivityPubTest do    alias Pleroma.Builders.ActivityBuilder    import Pleroma.Factory +  import Tesla.Mock + +  setup do +    mock(fn env -> apply(HttpRequestMock, :request, [env]) end) +    :ok +  end    describe "building a user from his ap id" do      test "it returns a user" do @@ -14,8 +20,8 @@ defmodule Pleroma.Web.ActivityPub.ActivityPubTest do        {:ok, user} = ActivityPub.make_user_from_ap_id(user_id)        assert user.ap_id == user_id        assert user.nickname == "admin@mastodon.example.org" -      assert user.info["source_data"] -      assert user.info["ap_enabled"] +      assert user.info.source_data +      assert user.info.ap_enabled        assert user.follower_address == "http://mastodon.example.org/users/admin/followers"      end    end diff --git a/test/web/activity_pub/transmogrifier_test.exs b/test/web/activity_pub/transmogrifier_test.exs index 829da0a65..fa526a222 100644 --- a/test/web/activity_pub/transmogrifier_test.exs +++ b/test/web/activity_pub/transmogrifier_test.exs @@ -12,6 +12,11 @@ defmodule Pleroma.Web.ActivityPub.TransmogrifierTest do    import Pleroma.Factory    alias Pleroma.Web.CommonAPI +  setup_all do +    Tesla.Mock.mock_global(fn env -> apply(HttpRequestMock, :request, [env]) end) +    :ok +  end +    describe "handle_incoming" do      test "it ignores an incoming notice if we already have it" do        activity = insert(:note_activity) @@ -92,7 +97,7 @@ defmodule Pleroma.Web.ActivityPub.TransmogrifierTest do        user = User.get_by_ap_id(object["actor"]) -      assert user.info["note_count"] == 1 +      assert user.info.note_count == 1      end      test "it works for incoming notices with hashtags" do @@ -307,7 +312,7 @@ defmodule Pleroma.Web.ActivityPub.TransmogrifierTest do                 }               ] -      assert user.info["banner"]["url"] == [ +      assert user.info.banner["url"] == [                 %{                   "href" =>                     "https://cd.niu.moe/accounts/headers/000/033/323/original/850b3448fa5fd477.png" @@ -337,7 +342,7 @@ defmodule Pleroma.Web.ActivityPub.TransmogrifierTest do        {:ok, %Activity{data: data, local: false}} = Transmogrifier.handle_incoming(update_data)        user = User.get_cached_by_ap_id(data["actor"]) -      assert user.info["locked"] == true +      assert user.info.locked == true      end      test "it works for incoming deletes" do @@ -543,7 +548,7 @@ defmodule Pleroma.Web.ActivityPub.TransmogrifierTest do      test "it works for incoming accepts which were orphaned" do        follower = insert(:user) -      followed = insert(:user, %{info: %{"locked" => true}}) +      followed = insert(:user, %{info: %User.Info{locked: true}})        {:ok, follow_activity} = ActivityPub.follow(follower, followed) @@ -565,7 +570,7 @@ defmodule Pleroma.Web.ActivityPub.TransmogrifierTest do      test "it works for incoming accepts which are referenced by IRI only" do        follower = insert(:user) -      followed = insert(:user, %{info: %{"locked" => true}}) +      followed = insert(:user, %{info: %User.Info{locked: true}})        {:ok, follow_activity} = ActivityPub.follow(follower, followed) @@ -585,7 +590,7 @@ defmodule Pleroma.Web.ActivityPub.TransmogrifierTest do      test "it fails for incoming accepts which cannot be correlated" do        follower = insert(:user) -      followed = insert(:user, %{info: %{"locked" => true}}) +      followed = insert(:user, %{info: %User.Info{locked: true}})        accept_data =          File.read!("test/fixtures/mastodon-accept-activity.json") @@ -604,7 +609,7 @@ defmodule Pleroma.Web.ActivityPub.TransmogrifierTest do      test "it fails for incoming rejects which cannot be correlated" do        follower = insert(:user) -      followed = insert(:user, %{info: %{"locked" => true}}) +      followed = insert(:user, %{info: %User.Info{locked: true}})        accept_data =          File.read!("test/fixtures/mastodon-reject-activity.json") @@ -623,7 +628,7 @@ defmodule Pleroma.Web.ActivityPub.TransmogrifierTest do      test "it works for incoming rejects which are orphaned" do        follower = insert(:user) -      followed = insert(:user, %{info: %{"locked" => true}}) +      followed = insert(:user, %{info: %User.Info{locked: true}})        {:ok, follower} = User.follow(follower, followed)        {:ok, _follow_activity} = ActivityPub.follow(follower, followed) @@ -648,7 +653,7 @@ defmodule Pleroma.Web.ActivityPub.TransmogrifierTest do      test "it works for incoming rejects which are referenced by IRI only" do        follower = insert(:user) -      followed = insert(:user, %{info: %{"locked" => true}}) +      followed = insert(:user, %{info: %User.Info{locked: true}})        {:ok, follower} = User.follow(follower, followed)        {:ok, follow_activity} = ActivityPub.follow(follower, followed) @@ -815,18 +820,18 @@ defmodule Pleroma.Web.ActivityPub.TransmogrifierTest do        assert "http://localhost:4001/users/rye@niu.moe/followers" in activity.recipients        user = Repo.get(User, user.id) -      assert user.info["note_count"] == 1 +      assert user.info.note_count == 1        {:ok, user} = Transmogrifier.upgrade_user_from_ap_id("https://niu.moe/users/rye") -      assert user.info["ap_enabled"] -      assert user.info["note_count"] == 1 +      assert user.info.ap_enabled +      assert user.info.note_count == 1        assert user.follower_address == "https://niu.moe/users/rye/followers"        # Wait for the background task        :timer.sleep(1000)        user = Repo.get(User, user.id) -      assert user.info["note_count"] == 1 +      assert user.info.note_count == 1        activity = Repo.get(Activity, activity.id)        assert user.follower_address in activity.recipients @@ -847,7 +852,7 @@ defmodule Pleroma.Web.ActivityPub.TransmogrifierTest do                       "https://cdn.niu.moe/accounts/headers/000/033/323/original/850b3448fa5fd477.png"                   }                 ] -             } = user.info["banner"] +             } = user.info.banner        refute "..." in activity.recipients diff --git a/test/web/admin_api/admin_api_controller_test.exs b/test/web/admin_api/admin_api_controller_test.exs index fa0cb71bf..9634ad7c5 100644 --- a/test/web/admin_api/admin_api_controller_test.exs +++ b/test/web/admin_api/admin_api_controller_test.exs @@ -8,7 +8,7 @@ defmodule Pleroma.Web.AdminAPI.AdminAPIControllerTest do    describe "/api/pleroma/admin/user" do      test "Delete" do -      admin = insert(:user, info: %{"is_admin" => true}) +      admin = insert(:user, info: %{is_admin: true})        user = insert(:user)        conn = @@ -21,7 +21,7 @@ defmodule Pleroma.Web.AdminAPI.AdminAPIControllerTest do      end      test "Create" do -      admin = insert(:user, info: %{"is_admin" => true}) +      admin = insert(:user, info: %{is_admin: true})        conn =          build_conn() @@ -39,7 +39,7 @@ defmodule Pleroma.Web.AdminAPI.AdminAPIControllerTest do    describe "/api/pleroma/admin/permission_group" do      test "GET is giving user_info" do -      admin = insert(:user, info: %{"is_admin" => true}) +      admin = insert(:user, info: %{is_admin: true})        conn =          build_conn() @@ -47,33 +47,30 @@ defmodule Pleroma.Web.AdminAPI.AdminAPIControllerTest do          |> put_req_header("accept", "application/json")          |> get("/api/pleroma/admin/permission_group/#{admin.nickname}") -      assert json_response(conn, 200) == admin.info +      assert json_response(conn, 200) == %{ +               "is_admin" => true, +               "is_moderator" => false +             }      end      test "/:right POST, can add to a permission group" do -      admin = insert(:user, info: %{"is_admin" => true}) +      admin = insert(:user, info: %{is_admin: true})        user = insert(:user) -      user_info = -        user.info -        |> Map.put("is_admin", true) -        conn =          build_conn()          |> assign(:user, admin)          |> put_req_header("accept", "application/json")          |> post("/api/pleroma/admin/permission_group/#{user.nickname}/admin") -      assert json_response(conn, 200) == user_info +      assert json_response(conn, 200) == %{ +               "is_admin" => true +             }      end      test "/:right DELETE, can remove from a permission group" do -      admin = insert(:user, info: %{"is_admin" => true}) -      user = insert(:user, info: %{"is_admin" => true}) - -      user_info = -        user.info -        |> Map.put("is_admin", false) +      admin = insert(:user, info: %{is_admin: true}) +      user = insert(:user, info: %{is_admin: true})        conn =          build_conn() @@ -81,12 +78,14 @@ defmodule Pleroma.Web.AdminAPI.AdminAPIControllerTest do          |> put_req_header("accept", "application/json")          |> delete("/api/pleroma/admin/permission_group/#{user.nickname}/admin") -      assert json_response(conn, 200) == user_info +      assert json_response(conn, 200) == %{ +               "is_admin" => false +             }      end    end    test "/api/pleroma/admin/invite_token" do -    admin = insert(:user, info: %{"is_admin" => true}) +    admin = insert(:user, info: %{is_admin: true})      conn =        build_conn() @@ -98,8 +97,8 @@ defmodule Pleroma.Web.AdminAPI.AdminAPIControllerTest do    end    test "/api/pleroma/admin/password_reset" do -    admin = insert(:user, info: %{"is_admin" => true}) -    user = insert(:user, info: %{"is_admin" => true}) +    admin = insert(:user, info: %{is_admin: true}) +    user = insert(:user)      conn =        build_conn() diff --git a/test/web/common_api/common_api_test.exs b/test/web/common_api/common_api_test.exs index cd36e409c..8fc65f4c0 100644 --- a/test/web/common_api/common_api_test.exs +++ b/test/web/common_api/common_api_test.exs @@ -17,7 +17,7 @@ defmodule Pleroma.Web.CommonAPI.Test do      CommonAPI.update(user)      user = User.get_cached_by_ap_id(user.ap_id) -    [karjalanpiirakka] = user.info["source_data"]["tag"] +    [karjalanpiirakka] = user.info.source_data["tag"]      assert karjalanpiirakka["name"] == ":karjalanpiirakka:"    end diff --git a/test/web/federator_test.exs b/test/web/federator_test.exs index 02e1ca76e..87bf73dbd 100644 --- a/test/web/federator_test.exs +++ b/test/web/federator_test.exs @@ -5,6 +5,11 @@ defmodule Pleroma.Web.FederatorTest do    import Pleroma.Factory    import Mock +  setup_all do +    Tesla.Mock.mock_global(fn env -> apply(HttpRequestMock, :request, [env]) end) +    :ok +  end +    test "enqueues an element according to priority" do      queue = [%{item: 1, priority: 2}] diff --git a/test/web/http_sigs/http_sig_test.exs b/test/web/http_sigs/http_sig_test.exs index b2bf8d61b..2e189d583 100644 --- a/test/web/http_sigs/http_sig_test.exs +++ b/test/web/http_sigs/http_sig_test.exs @@ -4,6 +4,12 @@ defmodule Pleroma.Web.HTTPSignaturesTest do    use Pleroma.DataCase    alias Pleroma.Web.HTTPSignatures    import Pleroma.Factory +  import Tesla.Mock + +  setup do +    mock(fn env -> apply(HttpRequestMock, :request, [env]) end) +    :ok +  end    @private_key hd(:public_key.pem_decode(File.read!("test/web/http_sigs/priv.key")))                 |> :public_key.pem_entry_decode() diff --git a/test/web/mastodon_api/account_view_test.exs b/test/web/mastodon_api/account_view_test.exs index dc52b92bc..a2d3a2547 100644 --- a/test/web/mastodon_api/account_view_test.exs +++ b/test/web/mastodon_api/account_view_test.exs @@ -17,7 +17,7 @@ defmodule Pleroma.Web.MastodonAPI.AccountViewTest do      user =        insert(:user, %{ -        info: %{"note_count" => 5, "follower_count" => 3, "source_data" => source_data}, +        info: %{note_count: 5, follower_count: 3, source_data: source_data},          nickname: "shp@shitposter.club",          name: ":karjalanpiirakka: shp",          bio: "<script src=\"invalid-html\"></script><span>valid html</span>", @@ -63,7 +63,7 @@ defmodule Pleroma.Web.MastodonAPI.AccountViewTest do    test "Represent a Service(bot) account" do      user =        insert(:user, %{ -        info: %{"note_count" => 5, "follower_count" => 3, "source_data" => %{"type" => "Service"}}, +        info: %{note_count: 5, follower_count: 3, source_data: %{"type" => "Service"}},          nickname: "shp@shitposter.club",          inserted_at: ~N[2017-08-15 15:47:06.597036]        }) diff --git a/test/web/mastodon_api/mastodon_api_controller_test.exs b/test/web/mastodon_api/mastodon_api_controller_test.exs index ad67cae6b..7cd98cde8 100644 --- a/test/web/mastodon_api/mastodon_api_controller_test.exs +++ b/test/web/mastodon_api/mastodon_api_controller_test.exs @@ -8,6 +8,12 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPIControllerTest do    import Pleroma.Factory    import ExUnit.CaptureLog +  import Tesla.Mock + +  setup do +    mock(fn env -> apply(HttpRequestMock, :request, [env]) end) +    :ok +  end    test "the home timeline", %{conn: conn} do      user = insert(:user) @@ -252,7 +258,7 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPIControllerTest do    end    test "verify_credentials default scope unlisted", %{conn: conn} do -    user = insert(:user, %{info: %{"default_scope" => "unlisted"}}) +    user = insert(:user, %{info: %Pleroma.User.Info{default_scope: "unlisted"}})      conn =        conn @@ -845,7 +851,7 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPIControllerTest do    describe "locked accounts" do      test "/api/v1/follow_requests works" do -      user = insert(:user, %{info: %{"locked" => true}}) +      user = insert(:user, %{info: %Pleroma.User.Info{locked: true}})        other_user = insert(:user)        {:ok, activity} = ActivityPub.follow(other_user, user) @@ -865,7 +871,7 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPIControllerTest do      end      test "/api/v1/follow_requests/:id/authorize works" do -      user = insert(:user, %{info: %{"locked" => true}}) +      user = insert(:user, %{info: %Pleroma.User.Info{locked: true}})        other_user = insert(:user)        {:ok, activity} = ActivityPub.follow(other_user, user) @@ -890,7 +896,7 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPIControllerTest do      end      test "verify_credentials", %{conn: conn} do -      user = insert(:user, %{info: %{"default_scope" => "private"}}) +      user = insert(:user, %{info: %Pleroma.User.Info{default_scope: "private"}})        conn =          conn @@ -902,7 +908,7 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPIControllerTest do      end      test "/api/v1/follow_requests/:id/reject works" do -      user = insert(:user, %{info: %{"locked" => true}}) +      user = insert(:user, %{info: %Pleroma.User.Info{locked: true}})        other_user = insert(:user)        {:ok, activity} = ActivityPub.follow(other_user, user) @@ -1105,7 +1111,7 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPIControllerTest do      refute User.blocks?(user, other_user)    end -  test "getting a list of domain blocks" do +  test "getting a list of domain blocks", %{conn: conn} do      user = insert(:user)      {:ok, user} = User.block_domain(user, "bad.site") @@ -1253,14 +1259,33 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPIControllerTest do    describe "updating credentials" do      test "updates the user's bio", %{conn: conn} do        user = insert(:user) +      user2 = insert(:user)        conn =          conn          |> assign(:user, user) -        |> patch("/api/v1/accounts/update_credentials", %{"note" => "I drink #cofe"}) +        |> patch("/api/v1/accounts/update_credentials", %{ +          "note" => "I drink #cofe with @#{user2.nickname}" +        })        assert user = json_response(conn, 200) -      assert user["note"] == "I drink #cofe" + +      assert user["note"] == +               "I drink <a href=\"http://localhost:4001/tag/cofe\">#cofe</a> with <span><a href=\"#{ +                 user2.ap_id +               }\">@<span>#{user2.nickname}</span></a></span>" +    end + +    test "updates the user's locking status", %{conn: conn} do +      user = insert(:user) + +      conn = +        conn +        |> assign(:user, user) +        |> patch("/api/v1/accounts/update_credentials", %{locked: "true"}) + +      assert user = json_response(conn, 200) +      assert user["locked"] == true      end      test "updates the user's name", %{conn: conn} do @@ -1289,8 +1314,8 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPIControllerTest do          |> assign(:user, user)          |> patch("/api/v1/accounts/update_credentials", %{"avatar" => new_avatar}) -      assert user = json_response(conn, 200) -      assert user["avatar"] != "https://placehold.it/48x48" +      assert user_response = json_response(conn, 200) +      assert user_response["avatar"] != User.avatar_url(user)      end      test "updates the user's banner", %{conn: conn} do @@ -1307,8 +1332,8 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPIControllerTest do          |> assign(:user, user)          |> patch("/api/v1/accounts/update_credentials", %{"header" => new_header}) -      assert user = json_response(conn, 200) -      assert user["header"] != "https://placehold.it/700x335" +      assert user_response = json_response(conn, 200) +      assert user_response["header"] != User.banner_url(user)      end    end diff --git a/test/web/mastodon_api/status_view_test.exs b/test/web/mastodon_api/status_view_test.exs index 31554a07d..9e69b3189 100644 --- a/test/web/mastodon_api/status_view_test.exs +++ b/test/web/mastodon_api/status_view_test.exs @@ -6,6 +6,12 @@ defmodule Pleroma.Web.MastodonAPI.StatusViewTest do    alias Pleroma.Web.OStatus    alias Pleroma.Web.CommonAPI    import Pleroma.Factory +  import Tesla.Mock + +  setup do +    mock(fn env -> apply(HttpRequestMock, :request, [env]) end) +    :ok +  end    test "a note with null content" do      note = insert(:note_activity) diff --git a/test/web/node_info_test.exs b/test/web/node_info_test.exs index a6376453c..a5b0b7869 100644 --- a/test/web/node_info_test.exs +++ b/test/web/node_info_test.exs @@ -4,7 +4,7 @@ defmodule Pleroma.Web.NodeInfoTest do    import Pleroma.Factory    test "nodeinfo shows staff accounts", %{conn: conn} do -    user = insert(:user, %{local: true, info: %{"is_moderator" => true}}) +    user = insert(:user, %{local: true, info: %{is_moderator: true}})      conn =        conn @@ -15,7 +15,7 @@ defmodule Pleroma.Web.NodeInfoTest do      assert user.ap_id in result["metadata"]["staffAccounts"]    end -  test "returns 404 when federation is disabled" do +  test "returns 404 when federation is disabled", %{conn: conn} do      instance =        Application.get_env(:pleroma, :instance)        |> Keyword.put(:federating, false) @@ -37,7 +37,7 @@ defmodule Pleroma.Web.NodeInfoTest do      Application.put_env(:pleroma, :instance, instance)    end -  test "returns 200 when federation is enabled" do +  test "returns 200 when federation is enabled", %{conn: conn} do      conn      |> get("/.well-known/nodeinfo")      |> json_response(200) diff --git a/test/web/ostatus/activity_representer_test.exs b/test/web/ostatus/activity_representer_test.exs index 8bf3bc775..a351510d8 100644 --- a/test/web/ostatus/activity_representer_test.exs +++ b/test/web/ostatus/activity_representer_test.exs @@ -7,6 +7,12 @@ defmodule Pleroma.Web.OStatus.ActivityRepresenterTest do    alias Pleroma.Web.OStatus    import Pleroma.Factory +  import Tesla.Mock + +  setup do +    mock(fn env -> apply(HttpRequestMock, :request, [env]) end) +    :ok +  end    test "an external note activity" do      incoming = File.read!("test/fixtures/mastodon-note-cw.xml") diff --git a/test/web/ostatus/ostatus_controller_test.exs b/test/web/ostatus/ostatus_controller_test.exs index 371c835c0..411e89e94 100644 --- a/test/web/ostatus/ostatus_controller_test.exs +++ b/test/web/ostatus/ostatus_controller_test.exs @@ -5,6 +5,11 @@ defmodule Pleroma.Web.OStatus.OStatusControllerTest do    alias Pleroma.Web.CommonAPI    alias Pleroma.Web.OStatus.ActivityRepresenter +  setup_all do +    Tesla.Mock.mock_global(fn env -> apply(HttpRequestMock, :request, [env]) end) +    :ok +  end +    test "decodes a salmon", %{conn: conn} do      user = insert(:user)      salmon = File.read!("test/fixtures/salmon.xml") @@ -31,14 +36,16 @@ defmodule Pleroma.Web.OStatus.OStatusControllerTest do      # Set a wrong magic-key for a user so it has to refetch      salmon_user = User.get_by_ap_id("http://gs.example.org:4040/index.php/user/1")      # Wrong key -    info = -      salmon_user.info -      |> Map.put( -        "magic_key", -        "RSA.pu0s-halox4tu7wmES1FVSx6u-4wc0YrUFXcqWXZG4-27UmbCOpMQftRCldNRfyA-qLbz-eqiwrong1EwUvjsD4cYbAHNGHwTvDOyx5AKthQUP44ykPv7kjKGh3DWKySJvcs9tlUG87hlo7AvnMo9pwRS_Zz2CacQ-MKaXyDepk=.AQAB" -      ) - -    Repo.update(User.info_changeset(salmon_user, %{info: info})) +    info_cng = +      User.Info.remote_user_creation(salmon_user.info, %{ +        magic_key: +          "RSA.pu0s-halox4tu7wmES1FVSx6u-4wc0YrUFXcqWXZG4-27UmbCOpMQftRCldNRfyA-qLbz-eqiwrong1EwUvjsD4cYbAHNGHwTvDOyx5AKthQUP44ykPv7kjKGh3DWKySJvcs9tlUG87hlo7AvnMo9pwRS_Zz2CacQ-MKaXyDepk=.AQAB" +      }) + +    cng = +      Ecto.Changeset.change(salmon_user) +      |> Ecto.Changeset.put_embed(:info, info_cng) +      |> Repo.update()      conn =        build_conn() diff --git a/test/web/ostatus/ostatus_test.exs b/test/web/ostatus/ostatus_test.exs index f95da8b0a..f3268e83d 100644 --- a/test/web/ostatus/ostatus_test.exs +++ b/test/web/ostatus/ostatus_test.exs @@ -6,6 +6,11 @@ defmodule Pleroma.Web.OStatusTest do    import Pleroma.Factory    import ExUnit.CaptureLog +  setup_all do +    Tesla.Mock.mock_global(fn env -> apply(HttpRequestMock, :request, [env]) end) +    :ok +  end +    test "don't insert create notes twice" do      incoming = File.read!("test/fixtures/incoming_note_activity.xml")      {:ok, [activity]} = OStatus.handle_incoming(incoming) @@ -17,7 +22,7 @@ defmodule Pleroma.Web.OStatusTest do      {:ok, [activity]} = OStatus.handle_incoming(incoming)      user = User.get_by_ap_id(activity.data["actor"]) -    assert user.info["note_count"] == 1 +    assert user.info.note_count == 1      assert activity.data["type"] == "Create"      assert activity.data["object"]["type"] == "Note" @@ -319,7 +324,7 @@ defmodule Pleroma.Web.OStatusTest do        assert user.name == "Constance Variable"        assert user.nickname == "lambadalambda@social.heldscal.la"        assert user.local == false -      assert user.info["uri"] == uri +      assert user.info.uri == uri        assert user.ap_id == uri        assert user.bio == "Call me Deacon Blues."        assert user.avatar["type"] == "Image" @@ -329,6 +334,38 @@ defmodule Pleroma.Web.OStatusTest do        assert user == user_again      end +    test "find_or_make_user sets all the nessary input fields" do +      uri = "https://social.heldscal.la/user/23211" +      {:ok, user} = OStatus.find_or_make_user(uri) + +      assert user.info == +               %Pleroma.User.Info{ +                 id: user.info.id, +                 ap_enabled: false, +                 background: %{}, +                 banner: %{}, +                 blocks: [], +                 deactivated: false, +                 default_scope: "public", +                 domain_blocks: [], +                 follower_count: 0, +                 is_admin: false, +                 is_moderator: false, +                 keys: nil, +                 locked: false, +                 no_rich_text: false, +                 note_count: 0, +                 settings: nil, +                 source_data: %{}, +                 hub: "https://social.heldscal.la/main/push/hub", +                 magic_key: +                   "RSA.uzg6r1peZU0vXGADWxGJ0PE34WvmhjUmydbX5YYdOiXfODVLwCMi1umGoqUDm-mRu4vNEdFBVJU1CpFA7dKzWgIsqsa501i2XqElmEveXRLvNRWFB6nG03Q5OUY2as8eE54BJm0p20GkMfIJGwP6TSFb-ICp3QjzbatuSPJ6xCE=.AQAB", +                 salmon: "https://social.heldscal.la/main/salmon/user/23211", +                 topic: "https://social.heldscal.la/api/statuses/user_timeline/23211.atom", +                 uri: "https://social.heldscal.la/user/23211" +               } +    end +      test "find_make_or_update_user takes an author element and returns an updated user" do        uri = "https://social.heldscal.la/user/23211" @@ -447,7 +484,7 @@ defmodule Pleroma.Web.OStatusTest do      end    end -  test "it doesn't add nil in the do field" do +  test "it doesn't add nil in the to field" do      incoming = File.read!("test/fixtures/nil_mention_entry.xml")      {:ok, [activity]} = OStatus.handle_incoming(incoming) diff --git a/test/web/ostatus/user_representer_test.exs b/test/web/ostatus/user_representer_test.exs index e41dfeb3d..82fb8e793 100644 --- a/test/web/ostatus/user_representer_test.exs +++ b/test/web/ostatus/user_representer_test.exs @@ -6,7 +6,7 @@ defmodule Pleroma.Web.OStatus.UserRepresenterTest do    alias Pleroma.User    test "returns a user with id, uri, name and link" do -    user = build(:user, nickname: "レイン") +    user = insert(:user, %{nickname: "レイン"})      tuple = UserRepresenter.to_simple_form(user)      res = :xmerl.export_simple_content(tuple, :xmerl_xml) |> to_string diff --git a/test/web/salmon/salmon_test.exs b/test/web/salmon/salmon_test.exs index 1b39b4b2d..23ccc038e 100644 --- a/test/web/salmon/salmon_test.exs +++ b/test/web/salmon/salmon_test.exs @@ -3,6 +3,7 @@ defmodule Pleroma.Web.Salmon.SalmonTest do    alias Pleroma.Web.Salmon    alias Pleroma.{Repo, Activity, User}    import Pleroma.Factory +  import Tesla.Mock    @magickey "RSA.pu0s-halox4tu7wmES1FVSx6u-4wc0YrUFXcqWXZG4-27UmbCOpMQftRCldNRfyA-qLbz-eqiwQhh-1EwUvjsD4cYbAHNGHwTvDOyx5AKthQUP44ykPv7kjKGh3DWKySJvcs9tlUG87hlo7AvnMo9pwRS_Zz2CacQ-MKaXyDepk=.AQAB" @@ -10,6 +11,11 @@ defmodule Pleroma.Web.Salmon.SalmonTest do    @magickey_friendica "RSA.AMwa8FUs2fWEjX0xN7yRQgegQffhBpuKNC6fa5VNSVorFjGZhRrlPMn7TQOeihlc9lBz2OsHlIedbYn2uJ7yCs0.AQAB" +  setup do +    mock(fn env -> apply(HttpRequestMock, :request, [env]) end) +    :ok +  end +    test "decodes a salmon" do      {:ok, salmon} = File.read("test/fixtures/salmon.xml")      {:ok, doc} = Salmon.decode_and_validate(@magickey, salmon) diff --git a/test/web/twitter_api/representers/activity_representer_test.exs b/test/web/twitter_api/representers/activity_representer_test.exs index 291fd5237..7cae4e4a1 100644 --- a/test/web/twitter_api/representers/activity_representer_test.exs +++ b/test/web/twitter_api/representers/activity_representer_test.exs @@ -58,7 +58,7 @@ defmodule Pleroma.Web.TwitterAPI.Representers.ActivityRepresenterTest do    end    test "an activity" do -    {:ok, user} = UserBuilder.insert() +    user = insert(:user)      #   {:ok, mentioned_user } = UserBuilder.insert(%{nickname: "shp", ap_id: "shp"})      mentioned_user = insert(:user, %{nickname: "shp"}) diff --git a/test/web/twitter_api/twitter_api_controller_test.exs b/test/web/twitter_api/twitter_api_controller_test.exs index 6bdcb4fd8..a6495ffc1 100644 --- a/test/web/twitter_api/twitter_api_controller_test.exs +++ b/test/web/twitter_api/twitter_api_controller_test.exs @@ -12,30 +12,47 @@ defmodule Pleroma.Web.TwitterAPI.ControllerTest do    import Pleroma.Factory -  describe "POST /api/account/verify_credentials" do -    setup [:valid_user] +  describe "POST /api/account/update_profile_banner" do +    test "it updates the banner", %{conn: conn} do +      user = insert(:user) -    test "without valid credentials", %{conn: conn} do -      conn = post(conn, "/api/account/verify_credentials.json") -      assert json_response(conn, 403) == %{"error" => "Invalid credentials."} +      new_banner = +        "data:image/gif;base64,R0lGODlhEAAQAMQAAORHHOVSKudfOulrSOp3WOyDZu6QdvCchPGolfO0o/XBs/fNwfjZ0frl3/zy7////wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACH5BAkAABAALAAAAAAQABAAAAVVICSOZGlCQAosJ6mu7fiyZeKqNKToQGDsM8hBADgUXoGAiqhSvp5QAnQKGIgUhwFUYLCVDFCrKUE1lBavAViFIDlTImbKC5Gm2hB0SlBCBMQiB0UjIQA7" + +      response = +        conn +        |> assign(:user, user) +        |> post(authenticated_twitter_api__path(conn, :update_banner), %{"banner" => new_banner}) +        |> json_response(200) + +      user = Repo.get(User, user.id) +      assert user.info.banner["type"] == "Image"      end +  end -    test "with credentials", %{conn: conn, user: user} do -      conn = +  describe "POST /api/qvitter/update_background_image" do +    test "it updates the background", %{conn: conn} do +      user = insert(:user) + +      new_bg = +        "data:image/gif;base64,R0lGODlhEAAQAMQAAORHHOVSKudfOulrSOp3WOyDZu6QdvCchPGolfO0o/XBs/fNwfjZ0frl3/zy7////wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACH5BAkAABAALAAAAAAQABAAAAVVICSOZGlCQAosJ6mu7fiyZeKqNKToQGDsM8hBADgUXoGAiqhSvp5QAnQKGIgUhwFUYLCVDFCrKUE1lBavAViFIDlTImbKC5Gm2hB0SlBCBMQiB0UjIQA7" + +      response =          conn -        |> with_credentials(user.nickname, "test") -        |> post("/api/account/verify_credentials.json") +        |> assign(:user, user) +        |> post(authenticated_twitter_api__path(conn, :update_background), %{"img" => new_bg}) +        |> json_response(200) -      assert response = json_response(conn, 200) -      assert response == UserView.render("show.json", %{user: user, token: response["token"]}) +      user = Repo.get(User, user.id) +      assert user.info.background["type"] == "Image"      end    end -  describe "POST /api/account/most_recent_notification" do +  describe "POST /api/account/verify_credentials" do      setup [:valid_user]      test "without valid credentials", %{conn: conn} do -      conn = post(conn, "/api/account/most_recent_notification.json") +      conn = post(conn, "/api/account/verify_credentials.json")        assert json_response(conn, 403) == %{"error" => "Invalid credentials."}      end @@ -43,11 +60,10 @@ defmodule Pleroma.Web.TwitterAPI.ControllerTest do        conn =          conn          |> with_credentials(user.nickname, "test") -        |> post("/api/account/most_recent_notification.json", %{id: "200"}) +        |> post("/api/account/verify_credentials.json") -      assert json_response(conn, 200) -      user = User.get_by_nickname(user.nickname) -      assert user.info["most_recent_notification"] == 200 +      assert response = json_response(conn, 200) +      assert response == UserView.render("show.json", %{user: user, token: response["token"]})      end    end @@ -87,7 +103,7 @@ defmodule Pleroma.Web.TwitterAPI.ControllerTest do    describe "GET /statuses/public_timeline.json" do      test "returns statuses", %{conn: conn} do -      {:ok, user} = UserBuilder.insert() +      user = insert(:user)        activities = ActivityBuilder.insert_list(30, %{}, %{user: user})        ActivityBuilder.insert_list(10, %{}, %{user: user})        since_id = List.last(activities).id @@ -591,7 +607,7 @@ defmodule Pleroma.Web.TwitterAPI.ControllerTest do          |> post("/api/blocks/destroy.json", %{user_id: blocked.id})        current_user = Repo.get(User, current_user.id) -      assert current_user.info["blocks"] == [] +      assert current_user.info.blocks == []        assert json_response(conn, 200) ==                 UserView.render("show.json", %{user: blocked, for: current_user}) @@ -939,18 +955,21 @@ defmodule Pleroma.Web.TwitterAPI.ControllerTest do    describe "POST /api/account/update_profile.json" do      test "it updates a user's profile", %{conn: conn} do        user = insert(:user) +      user2 = insert(:user)        conn =          conn          |> assign(:user, user)          |> post("/api/account/update_profile.json", %{            "name" => "new name", -          "description" => "new description" +          "description" => "hi @#{user2.nickname}"          })        user = Repo.get!(User, user.id)        assert user.name == "new name" -      assert user.bio == "new description" + +      assert user.bio == +               "hi <span><a class='mention' href='#{user2.ap_id}'>@<span>#{user2.nickname}</span></a></span>"        assert json_response(conn, 200) == UserView.render("user.json", %{user: user, for: user})      end @@ -966,7 +985,7 @@ defmodule Pleroma.Web.TwitterAPI.ControllerTest do          })        user = Repo.get!(User, user.id) -      assert user.info["locked"] == true +      assert user.info.locked == true        assert json_response(conn, 200) == UserView.render("user.json", %{user: user, for: user})      end @@ -982,7 +1001,7 @@ defmodule Pleroma.Web.TwitterAPI.ControllerTest do          })        user = Repo.get!(User, user.id) -      assert user.info["locked"] == false +      assert user.info.locked == false        assert json_response(conn, 200) == UserView.render("user.json", %{user: user, for: user})      end @@ -1153,10 +1172,10 @@ defmodule Pleroma.Web.TwitterAPI.ControllerTest do    describe "GET /api/pleroma/friend_requests" do      test "it lists friend requests" do -      user = insert(:user, %{info: %{"locked" => true}}) +      user = insert(:user)        other_user = insert(:user) -      {:ok, activity} = ActivityPub.follow(other_user, user) +      {:ok, _activity} = ActivityPub.follow(other_user, user)        user = Repo.get(User, user.id)        other_user = Repo.get(User, other_user.id) @@ -1175,10 +1194,10 @@ defmodule Pleroma.Web.TwitterAPI.ControllerTest do    describe "POST /api/pleroma/friendships/approve" do      test "it approves a friend request" do -      user = insert(:user, %{info: %{"locked" => true}}) +      user = insert(:user)        other_user = insert(:user) -      {:ok, activity} = ActivityPub.follow(other_user, user) +      {:ok, _activity} = ActivityPub.follow(other_user, user)        user = Repo.get(User, user.id)        other_user = Repo.get(User, other_user.id) @@ -1198,10 +1217,10 @@ defmodule Pleroma.Web.TwitterAPI.ControllerTest do    describe "POST /api/pleroma/friendships/deny" do      test "it denies a friend request" do -      user = insert(:user, %{info: %{"locked" => true}}) +      user = insert(:user)        other_user = insert(:user) -      {:ok, activity} = ActivityPub.follow(other_user, user) +      {:ok, _activity} = ActivityPub.follow(other_user, user)        user = Repo.get(User, user.id)        other_user = Repo.get(User, other_user.id) diff --git a/test/web/twitter_api/twitter_api_test.exs b/test/web/twitter_api/twitter_api_test.exs index 8b9920bd9..28230699f 100644 --- a/test/web/twitter_api/twitter_api_test.exs +++ b/test/web/twitter_api/twitter_api_test.exs @@ -10,7 +10,7 @@ defmodule Pleroma.Web.TwitterAPI.TwitterAPITest do    test "create a status" do      user = insert(:user) -    _mentioned_user = UserBuilder.insert(%{nickname: "shp", ap_id: "shp"}) +    _mentioned_user = insert(:user, %{nickname: "shp", ap_id: "shp"})      object_data = %{        "type" => "Image", @@ -67,7 +67,7 @@ defmodule Pleroma.Web.TwitterAPI.TwitterAPITest do      user = User.get_by_ap_id(user.ap_id) -    assert user.info["note_count"] == 1 +    assert user.info.note_count == 1    end    test "create a status that is a reply" do @@ -116,7 +116,7 @@ defmodule Pleroma.Web.TwitterAPI.TwitterAPITest do      assert User.ap_followers(followed) in user.following      followed = User.get_by_ap_id(followed.ap_id) -    assert followed.info["follower_count"] == 1 +    assert followed.info.follower_count == 1      {:error, msg} = TwitterAPI.follow(user, %{"screen_name" => followed.nickname})      assert msg == "Could not follow user: #{followed.nickname} is already on your list." @@ -169,7 +169,7 @@ defmodule Pleroma.Web.TwitterAPI.TwitterAPITest do      {:ok, user, _unblocked} = TwitterAPI.block(user, %{"user_id" => unblocked.id})      {:ok, user, _unblocked} = TwitterAPI.unblock(user, %{"user_id" => unblocked.id}) -    assert user.info["blocks"] == [] +    assert user.info.blocks == []    end    test "Unblock another user using screen_name" do @@ -178,7 +178,7 @@ defmodule Pleroma.Web.TwitterAPI.TwitterAPITest do      {:ok, user, _unblocked} = TwitterAPI.block(user, %{"screen_name" => unblocked.nickname})      {:ok, user, _unblocked} = TwitterAPI.unblock(user, %{"screen_name" => unblocked.nickname}) -    assert user.info["blocks"] == [] +    assert user.info.blocks == []    end    test "upload a file" do @@ -257,6 +257,35 @@ defmodule Pleroma.Web.TwitterAPI.TwitterAPITest do               UserView.render("show.json", %{user: fetched_user})    end +  test "it registers a new user and parses mentions in the bio" do +    data1 = %{ +      "nickname" => "john", +      "email" => "john@gmail.com", +      "fullname" => "John Doe", +      "bio" => "test", +      "password" => "bear", +      "confirm" => "bear" +    } + +    {:ok, user1} = TwitterAPI.register_user(data1) + +    data2 = %{ +      "nickname" => "lain", +      "email" => "lain@wired.jp", +      "fullname" => "lain iwakura", +      "bio" => "@john test", +      "password" => "bear", +      "confirm" => "bear" +    } + +    {:ok, user2} = TwitterAPI.register_user(data2) + +    expected_text = +      "<span><a class='mention' href='#{user1.ap_id}'>@<span>john</span></a></span> test" + +    assert user2.bio == expected_text +  end +    @moduletag skip: "needs 'registrations_open: false' in config"    test "it registers a new user via invite token and returns the user." do      {:ok, token} = UserInviteToken.create_token() diff --git a/test/web/twitter_api/views/user_view_test.exs b/test/web/twitter_api/views/user_view_test.exs index 2c583c0d3..e69ca24a9 100644 --- a/test/web/twitter_api/views/user_view_test.exs +++ b/test/web/twitter_api/views/user_view_test.exs @@ -31,10 +31,10 @@ defmodule Pleroma.Web.TwitterAPI.UserViewTest do      expected =        "<img height=\"32px\" width=\"32px\" alt=\"karjalanpiirakka\" title=\"karjalanpiirakka\" src=\"/file.png\" /> man" -    user = %{ -      user -      | info: %{ -          "source_data" => %{ +    user = +      insert(:user, %{ +        info: %{ +          source_data: %{              "tag" => [                %{                  "type" => "Emoji", @@ -43,10 +43,10 @@ defmodule Pleroma.Web.TwitterAPI.UserViewTest do                }              ]            } -        } -    } +        }, +        name: ":karjalanpiirakka: man" +      }) -    user = %{user | name: ":karjalanpiirakka: man"}      represented = UserView.render("show.json", %{user: user})      assert represented["name_html"] == expected    end @@ -103,7 +103,7 @@ defmodule Pleroma.Web.TwitterAPI.UserViewTest do    end    test "A user for a given other follower", %{user: user} do -    {:ok, follower} = UserBuilder.insert(%{following: [User.ap_followers(user)]}) +    follower = insert(:user, %{following: [User.ap_followers(user)]})      {:ok, user} = User.update_follower_count(user)      image = "http://localhost:4001/images/avi.png"      banner = "http://localhost:4001/images/banner.png" @@ -186,7 +186,7 @@ defmodule Pleroma.Web.TwitterAPI.UserViewTest do    end    test "a user that is a moderator" do -    user = insert(:user, %{info: %{"is_moderator" => true}}) +    user = insert(:user, %{info: %{is_moderator: true}})      represented = UserView.render("show.json", %{user: user, for: user})      assert represented["rights"]["delete_others_notice"] @@ -250,7 +250,7 @@ defmodule Pleroma.Web.TwitterAPI.UserViewTest do      user =        insert(:user, %{          info: %{ -          "source_data" => %{ +          source_data: %{              "attachment" =>                Enum.map(fields, fn field -> Map.put(field, "type", "PropertyValue") end)            } diff --git a/test/web/web_finger/web_finger_test.exs b/test/web/web_finger/web_finger_test.exs index 99bf210ea..32eff9b7c 100644 --- a/test/web/web_finger/web_finger_test.exs +++ b/test/web/web_finger/web_finger_test.exs @@ -2,6 +2,12 @@ defmodule Pleroma.Web.WebFingerTest do    use Pleroma.DataCase    alias Pleroma.Web.WebFinger    import Pleroma.Factory +  import Tesla.Mock + +  setup do +    mock(fn env -> apply(HttpRequestMock, :request, [env]) end) +    :ok +  end    describe "host meta" do      test "returns a link to the xml lrdd" do @@ -99,15 +105,15 @@ defmodule Pleroma.Web.WebFingerTest do    describe "ensure_keys_present" do      test "it creates keys for a user and stores them in info" do        user = insert(:user) -      refute is_binary(user.info["keys"]) +      refute is_binary(user.info.keys)        {:ok, user} = WebFinger.ensure_keys_present(user) -      assert is_binary(user.info["keys"]) +      assert is_binary(user.info.keys)      end      test "it doesn't create keys if there already are some" do -      user = insert(:user, %{info: %{"keys" => "xxx"}}) +      user = insert(:user, %{info: %{keys: "xxx"}})        {:ok, user} = WebFinger.ensure_keys_present(user) -      assert user.info["keys"] == "xxx" +      assert user.info.keys == "xxx"      end    end  end diff --git a/test/web/websub/websub_test.exs b/test/web/websub/websub_test.exs index 5914a37fc..47d1a88e1 100644 --- a/test/web/websub/websub_test.exs +++ b/test/web/websub/websub_test.exs @@ -10,6 +10,12 @@ defmodule Pleroma.Web.WebsubTest do    alias Pleroma.Web.Websub.{WebsubServerSubscription, WebsubClientSubscription}    import Pleroma.Factory    alias Pleroma.Web.Router.Helpers +  import Tesla.Mock + +  setup do +    mock(fn env -> apply(HttpRequestMock, :request, [env]) end) +    :ok +  end    test "a verification of a request that is accepted" do      sub = insert(:websub_subscription) @@ -26,8 +32,8 @@ defmodule Pleroma.Web.WebsubTest do        assert String.to_integer(seconds) > 0        {:ok, -       %HTTPoison.Response{ -         status_code: 200, +       %Tesla.Env{ +         status: 200,           body: challenge         }}      end @@ -41,8 +47,8 @@ defmodule Pleroma.Web.WebsubTest do      getter = fn _path, _headers, _options ->        {:ok, -       %HTTPoison.Response{ -         status_code: 500, +       %Tesla.Env{ +         status: 500,           body: ""         }}      end @@ -99,7 +105,7 @@ defmodule Pleroma.Web.WebsubTest do    test "initiate a subscription for a given user and topic" do      subscriber = insert(:user) -    user = insert(:user, %{info: %{"topic" => "some_topic", "hub" => "some_hub"}}) +    user = insert(:user, %{info: %Pleroma.User.Info{topic: "some_topic", hub: "some_hub"}})      {:ok, websub} = Websub.subscribe(subscriber, user, &accepting_verifier/1)      assert websub.subscribers == [subscriber.ap_id] @@ -113,12 +119,7 @@ defmodule Pleroma.Web.WebsubTest do    test "discovers the hub and canonical url" do      topic = "https://mastodon.social/users/lambadalambda.atom" -    getter = fn ^topic -> -      doc = File.read!("test/fixtures/lambadalambda.atom") -      {:ok, %{status_code: 200, body: doc}} -    end - -    {:ok, discovered} = Websub.gather_feed_data(topic, getter) +    {:ok, discovered} = Websub.gather_feed_data(topic)      expected = %{        "hub" => "https://mastodon.social/api/push", @@ -158,7 +159,7 @@ defmodule Pleroma.Web.WebsubTest do                   websub.id                 ) -      {:ok, %{status_code: 202}} +      {:ok, %{status: 202}}      end      task = Task.async(fn -> Websub.request_subscription(websub, poster) end) @@ -177,7 +178,7 @@ defmodule Pleroma.Web.WebsubTest do      websub = insert(:websub_client_subscription, %{hub: hub, topic: topic})      poster = fn ^hub, {:form, _data}, _headers -> -      {:ok, %{status_code: 202}} +      {:ok, %{status: 202}}      end      {:error, websub} = Websub.request_subscription(websub, poster, 1000) @@ -186,7 +187,7 @@ defmodule Pleroma.Web.WebsubTest do      websub = insert(:websub_client_subscription, %{hub: hub, topic: topic})      poster = fn ^hub, {:form, _data}, _headers -> -      {:ok, %{status_code: 400}} +      {:ok, %{status: 400}}      end      {:error, websub} = Websub.request_subscription(websub, poster, 1000) @@ -209,6 +210,7 @@ defmodule Pleroma.Web.WebsubTest do          insert(:websub_client_subscription, %{            valid_until: NaiveDateTime.add(now, 2 * day),            topic: "http://example.org/still_good", +          hub: "http://example.org/still_good",            state: "accepted"          }) @@ -216,6 +218,7 @@ defmodule Pleroma.Web.WebsubTest do          insert(:websub_client_subscription, %{            valid_until: NaiveDateTime.add(now, day - 100),            topic: "http://example.org/needs_refresh", +          hub: "http://example.org/needs_refresh",            state: "accepted"          }) | 
