diff options
| author | Egor Kislitsyn <egor@kislitsyn.com> | 2019-05-17 19:57:14 +0700 | 
|---|---|---|
| committer | Egor Kislitsyn <egor@kislitsyn.com> | 2019-05-17 19:57:14 +0700 | 
| commit | 557f0e33a7de7ef89c72441ffc3a9c09c56fe9a7 (patch) | |
| tree | 8044adbc3645ccd1c7dce13b396e7d23db51a0fb /test/web | |
| parent | f2936e0a0723956c167a06dc51518da172a508b2 (diff) | |
| parent | e5b34f5e0544371603bc2b570c26ede3182c2f8b (diff) | |
| download | pleroma-557f0e33a7de7ef89c72441ffc3a9c09c56fe9a7.tar.gz pleroma-557f0e33a7de7ef89c72441ffc3a9c09c56fe9a7.zip | |
Merge remote-tracking branch 'pleroma/develop' into feature/addressable-lists
Diffstat (limited to 'test/web')
| -rw-r--r-- | test/web/activity_pub/activity_pub_test.exs | 35 | ||||
| -rw-r--r-- | test/web/activity_pub/mrf/simple_policy_test.exs | 192 | ||||
| -rw-r--r-- | test/web/activity_pub/visibilty_test.exs | 10 | ||||
| -rw-r--r-- | test/web/admin_api/admin_api_controller_test.exs | 327 | ||||
| -rw-r--r-- | test/web/common_api/common_api_test.exs | 37 | ||||
| -rw-r--r-- | test/web/mastodon_api/mastodon_api_controller_test.exs | 12 | ||||
| -rw-r--r-- | test/web/ostatus/ostatus_test.exs | 6 | 
7 files changed, 603 insertions, 16 deletions
| diff --git a/test/web/activity_pub/activity_pub_test.exs b/test/web/activity_pub/activity_pub_test.exs index e38de388b..11fd3d244 100644 --- a/test/web/activity_pub/activity_pub_test.exs +++ b/test/web/activity_pub/activity_pub_test.exs @@ -462,6 +462,29 @@ defmodule Pleroma.Web.ActivityPub.ActivityPubTest do      refute Enum.member?(activities, activity_three.id)    end +  test "doesn't return activities from blocked domains" do +    domain = "dogwhistle.zone" +    domain_user = insert(:user, %{ap_id: "https://#{domain}/@pundit"}) +    note = insert(:note, %{data: %{"actor" => domain_user.ap_id}}) +    activity = insert(:note_activity, %{note: note}) +    user = insert(:user) +    {:ok, user} = User.block_domain(user, domain) + +    activities = +      ActivityPub.fetch_activities([], %{"blocking_user" => user, "skip_preload" => true}) + +    refute activity in activities + +    followed_user = insert(:user) +    ActivityPub.follow(user, followed_user) +    {:ok, repeat_activity, _} = CommonAPI.repeat(activity.id, followed_user) + +    activities = +      ActivityPub.fetch_activities([], %{"blocking_user" => user, "skip_preload" => true}) + +    refute repeat_activity in activities +  end +    test "doesn't return muted activities" do      activity_one = insert(:note_activity)      activity_two = insert(:note_activity) @@ -960,17 +983,21 @@ defmodule Pleroma.Web.ActivityPub.ActivityPubTest do            "in_reply_to_status_id" => private_activity_2.id          }) -      activities = ActivityPub.fetch_activities([user1.ap_id | user1.following]) +      activities = +        ActivityPub.fetch_activities([user1.ap_id | user1.following]) +        |> Enum.map(fn a -> a.id end)        private_activity_1 = Activity.get_by_ap_id_with_object(private_activity_1.data["id"]) -      assert [public_activity, private_activity_1, private_activity_3] == activities +      assert [public_activity.id, private_activity_1.id, private_activity_3.id] == activities        assert length(activities) == 3 -      activities = ActivityPub.contain_timeline(activities, user1) +      activities = +        ActivityPub.fetch_activities([user1.ap_id | user1.following], %{"user" => user1}) +        |> Enum.map(fn a -> a.id end) -      assert [public_activity, private_activity_1] == activities +      assert [public_activity.id, private_activity_1.id] == activities        assert length(activities) == 2      end    end diff --git a/test/web/activity_pub/mrf/simple_policy_test.exs b/test/web/activity_pub/mrf/simple_policy_test.exs new file mode 100644 index 000000000..1e0511975 --- /dev/null +++ b/test/web/activity_pub/mrf/simple_policy_test.exs @@ -0,0 +1,192 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2019 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only + +defmodule Pleroma.Web.ActivityPub.MRF.SimplePolicyTest do +  use Pleroma.DataCase +  import Pleroma.Factory +  alias Pleroma.Config +  alias Pleroma.Web.ActivityPub.MRF.SimplePolicy + +  setup do +    orig = Config.get!(:mrf_simple) + +    Config.put(:mrf_simple, +      media_removal: [], +      media_nsfw: [], +      federated_timeline_removal: [], +      reject: [], +      accept: [] +    ) + +    on_exit(fn -> +      Config.put(:mrf_simple, orig) +    end) +  end + +  describe "when :media_removal" do +    test "is empty" do +      Config.put([:mrf_simple, :media_removal], []) +      media_message = build_media_message() +      local_message = build_local_message() + +      assert SimplePolicy.filter(media_message) == {:ok, media_message} +      assert SimplePolicy.filter(local_message) == {:ok, local_message} +    end + +    test "has a matching host" do +      Config.put([:mrf_simple, :media_removal], ["remote.instance"]) +      media_message = build_media_message() +      local_message = build_local_message() + +      assert SimplePolicy.filter(media_message) == +               {:ok, +                media_message +                |> Map.put("object", Map.delete(media_message["object"], "attachment"))} + +      assert SimplePolicy.filter(local_message) == {:ok, local_message} +    end +  end + +  describe "when :media_nsfw" do +    test "is empty" do +      Config.put([:mrf_simple, :media_nsfw], []) +      media_message = build_media_message() +      local_message = build_local_message() + +      assert SimplePolicy.filter(media_message) == {:ok, media_message} +      assert SimplePolicy.filter(local_message) == {:ok, local_message} +    end + +    test "has a matching host" do +      Config.put([:mrf_simple, :media_nsfw], ["remote.instance"]) +      media_message = build_media_message() +      local_message = build_local_message() + +      assert SimplePolicy.filter(media_message) == +               {:ok, +                media_message +                |> put_in(["object", "tag"], ["foo", "nsfw"]) +                |> put_in(["object", "sensitive"], true)} + +      assert SimplePolicy.filter(local_message) == {:ok, local_message} +    end +  end + +  defp build_media_message do +    %{ +      "actor" => "https://remote.instance/users/bob", +      "type" => "Create", +      "object" => %{ +        "attachment" => [%{}], +        "tag" => ["foo"], +        "sensitive" => false +      } +    } +  end + +  describe "when :federated_timeline_removal" do +    test "is empty" do +      Config.put([:mrf_simple, :federated_timeline_removal], []) +      {_, ftl_message} = build_ftl_actor_and_message() +      local_message = build_local_message() + +      assert SimplePolicy.filter(ftl_message) == {:ok, ftl_message} +      assert SimplePolicy.filter(local_message) == {:ok, local_message} +    end + +    test "has a matching host" do +      {actor, ftl_message} = build_ftl_actor_and_message() + +      ftl_message_actor_host = +        ftl_message +        |> Map.fetch!("actor") +        |> URI.parse() +        |> Map.fetch!(:host) + +      Config.put([:mrf_simple, :federated_timeline_removal], [ftl_message_actor_host]) +      local_message = build_local_message() + +      assert {:ok, ftl_message} = SimplePolicy.filter(ftl_message) +      assert actor.follower_address in ftl_message["to"] +      refute actor.follower_address in ftl_message["cc"] +      refute "https://www.w3.org/ns/activitystreams#Public" in ftl_message["to"] +      assert "https://www.w3.org/ns/activitystreams#Public" in ftl_message["cc"] + +      assert SimplePolicy.filter(local_message) == {:ok, local_message} +    end +  end + +  defp build_ftl_actor_and_message do +    actor = insert(:user) + +    {actor, +     %{ +       "actor" => actor.ap_id, +       "to" => ["https://www.w3.org/ns/activitystreams#Public", "http://foo.bar/baz"], +       "cc" => [actor.follower_address, "http://foo.bar/qux"] +     }} +  end + +  describe "when :reject" do +    test "is empty" do +      Config.put([:mrf_simple, :reject], []) + +      remote_message = build_remote_message() + +      assert SimplePolicy.filter(remote_message) == {:ok, remote_message} +    end + +    test "has a matching host" do +      Config.put([:mrf_simple, :reject], ["remote.instance"]) + +      remote_message = build_remote_message() + +      assert SimplePolicy.filter(remote_message) == {:reject, nil} +    end +  end + +  describe "when :accept" do +    test "is empty" do +      Config.put([:mrf_simple, :accept], []) + +      local_message = build_local_message() +      remote_message = build_remote_message() + +      assert SimplePolicy.filter(local_message) == {:ok, local_message} +      assert SimplePolicy.filter(remote_message) == {:ok, remote_message} +    end + +    test "is not empty but it doesn't have a matching host" do +      Config.put([:mrf_simple, :accept], ["non.matching.remote"]) + +      local_message = build_local_message() +      remote_message = build_remote_message() + +      assert SimplePolicy.filter(local_message) == {:ok, local_message} +      assert SimplePolicy.filter(remote_message) == {:reject, nil} +    end + +    test "has a matching host" do +      Config.put([:mrf_simple, :accept], ["remote.instance"]) + +      local_message = build_local_message() +      remote_message = build_remote_message() + +      assert SimplePolicy.filter(local_message) == {:ok, local_message} +      assert SimplePolicy.filter(remote_message) == {:ok, remote_message} +    end +  end + +  defp build_local_message do +    %{ +      "actor" => "#{Pleroma.Web.base_url()}/users/alice", +      "to" => [], +      "cc" => [] +    } +  end + +  defp build_remote_message do +    %{"actor" => "https://remote.instance/users/bob"} +  end +end diff --git a/test/web/activity_pub/visibilty_test.exs b/test/web/activity_pub/visibilty_test.exs index 9c03c8be2..e2584f635 100644 --- a/test/web/activity_pub/visibilty_test.exs +++ b/test/web/activity_pub/visibilty_test.exs @@ -96,6 +96,16 @@ defmodule Pleroma.Web.ActivityPub.VisibilityTest do      refute Visibility.visible_for_user?(direct, unrelated)    end +  test "doesn't die when the user doesn't exist", +       %{ +         direct: direct, +         user: user +       } do +    Repo.delete(user) +    Cachex.clear(:user_cache) +    refute Visibility.is_private?(direct) +  end +    test "get_visibility", %{      public: public,      private: private, diff --git a/test/web/admin_api/admin_api_controller_test.exs b/test/web/admin_api/admin_api_controller_test.exs index 6c1897b5a..ca12c7215 100644 --- a/test/web/admin_api/admin_api_controller_test.exs +++ b/test/web/admin_api/admin_api_controller_test.exs @@ -5,8 +5,10 @@  defmodule Pleroma.Web.AdminAPI.AdminAPIControllerTest do    use Pleroma.Web.ConnCase +  alias Pleroma.Activity    alias Pleroma.User    alias Pleroma.UserInviteToken +  alias Pleroma.Web.CommonAPI    import Pleroma.Factory    describe "/api/pleroma/admin/users" do @@ -949,4 +951,329 @@ defmodule Pleroma.Web.AdminAPI.AdminAPIControllerTest do               }      end    end + +  describe "GET /api/pleroma/admin/reports/:id" do +    setup %{conn: conn} do +      admin = insert(:user, info: %{is_admin: true}) + +      %{conn: assign(conn, :user, admin)} +    end + +    test "returns report by its id", %{conn: conn} do +      [reporter, target_user] = insert_pair(:user) +      activity = insert(:note_activity, user: target_user) + +      {:ok, %{id: report_id}} = +        CommonAPI.report(reporter, %{ +          "account_id" => target_user.id, +          "comment" => "I feel offended", +          "status_ids" => [activity.id] +        }) + +      response = +        conn +        |> get("/api/pleroma/admin/reports/#{report_id}") +        |> json_response(:ok) + +      assert response["id"] == report_id +    end + +    test "returns 404 when report id is invalid", %{conn: conn} do +      conn = get(conn, "/api/pleroma/admin/reports/test") + +      assert json_response(conn, :not_found) == "Not found" +    end +  end + +  describe "PUT /api/pleroma/admin/reports/:id" do +    setup %{conn: conn} do +      admin = insert(:user, info: %{is_admin: true}) +      [reporter, target_user] = insert_pair(:user) +      activity = insert(:note_activity, user: target_user) + +      {:ok, %{id: report_id}} = +        CommonAPI.report(reporter, %{ +          "account_id" => target_user.id, +          "comment" => "I feel offended", +          "status_ids" => [activity.id] +        }) + +      %{conn: assign(conn, :user, admin), id: report_id} +    end + +    test "mark report as resolved", %{conn: conn, id: id} do +      response = +        conn +        |> put("/api/pleroma/admin/reports/#{id}", %{"state" => "resolved"}) +        |> json_response(:ok) + +      assert response["state"] == "resolved" +    end + +    test "closes report", %{conn: conn, id: id} do +      response = +        conn +        |> put("/api/pleroma/admin/reports/#{id}", %{"state" => "closed"}) +        |> json_response(:ok) + +      assert response["state"] == "closed" +    end + +    test "returns 400 when state is unknown", %{conn: conn, id: id} do +      conn = +        conn +        |> put("/api/pleroma/admin/reports/#{id}", %{"state" => "test"}) + +      assert json_response(conn, :bad_request) == "Unsupported state" +    end + +    test "returns 404 when report is not exist", %{conn: conn} do +      conn = +        conn +        |> put("/api/pleroma/admin/reports/test", %{"state" => "closed"}) + +      assert json_response(conn, :not_found) == "Not found" +    end +  end + +  describe "GET /api/pleroma/admin/reports" do +    setup %{conn: conn} do +      admin = insert(:user, info: %{is_admin: true}) + +      %{conn: assign(conn, :user, admin)} +    end + +    test "returns empty response when no reports created", %{conn: conn} do +      response = +        conn +        |> get("/api/pleroma/admin/reports") +        |> json_response(:ok) + +      assert Enum.empty?(response["reports"]) +    end + +    test "returns reports", %{conn: conn} do +      [reporter, target_user] = insert_pair(:user) +      activity = insert(:note_activity, user: target_user) + +      {:ok, %{id: report_id}} = +        CommonAPI.report(reporter, %{ +          "account_id" => target_user.id, +          "comment" => "I feel offended", +          "status_ids" => [activity.id] +        }) + +      response = +        conn +        |> get("/api/pleroma/admin/reports") +        |> json_response(:ok) + +      [report] = response["reports"] + +      assert length(response["reports"]) == 1 +      assert report["id"] == report_id +    end + +    test "returns reports with specified state", %{conn: conn} do +      [reporter, target_user] = insert_pair(:user) +      activity = insert(:note_activity, user: target_user) + +      {:ok, %{id: first_report_id}} = +        CommonAPI.report(reporter, %{ +          "account_id" => target_user.id, +          "comment" => "I feel offended", +          "status_ids" => [activity.id] +        }) + +      {:ok, %{id: second_report_id}} = +        CommonAPI.report(reporter, %{ +          "account_id" => target_user.id, +          "comment" => "I don't like this user" +        }) + +      CommonAPI.update_report_state(second_report_id, "closed") + +      response = +        conn +        |> get("/api/pleroma/admin/reports", %{ +          "state" => "open" +        }) +        |> json_response(:ok) + +      [open_report] = response["reports"] + +      assert length(response["reports"]) == 1 +      assert open_report["id"] == first_report_id + +      response = +        conn +        |> get("/api/pleroma/admin/reports", %{ +          "state" => "closed" +        }) +        |> json_response(:ok) + +      [closed_report] = response["reports"] + +      assert length(response["reports"]) == 1 +      assert closed_report["id"] == second_report_id + +      response = +        conn +        |> get("/api/pleroma/admin/reports", %{ +          "state" => "resolved" +        }) +        |> json_response(:ok) + +      assert Enum.empty?(response["reports"]) +    end + +    test "returns 403 when requested by a non-admin" do +      user = insert(:user) + +      conn = +        build_conn() +        |> assign(:user, user) +        |> get("/api/pleroma/admin/reports") + +      assert json_response(conn, :forbidden) == %{"error" => "User is not admin."} +    end + +    test "returns 403 when requested by anonymous" do +      conn = +        build_conn() +        |> get("/api/pleroma/admin/reports") + +      assert json_response(conn, :forbidden) == %{"error" => "Invalid credentials."} +    end +  end + +  describe "POST /api/pleroma/admin/reports/:id/respond" do +    setup %{conn: conn} do +      admin = insert(:user, info: %{is_admin: true}) + +      %{conn: assign(conn, :user, admin)} +    end + +    test "returns created dm", %{conn: conn} do +      [reporter, target_user] = insert_pair(:user) +      activity = insert(:note_activity, user: target_user) + +      {:ok, %{id: report_id}} = +        CommonAPI.report(reporter, %{ +          "account_id" => target_user.id, +          "comment" => "I feel offended", +          "status_ids" => [activity.id] +        }) + +      response = +        conn +        |> post("/api/pleroma/admin/reports/#{report_id}/respond", %{ +          "status" => "I will check it out" +        }) +        |> json_response(:ok) + +      recipients = Enum.map(response["mentions"], & &1["username"]) + +      assert conn.assigns[:user].nickname in recipients +      assert reporter.nickname in recipients +      assert response["content"] == "I will check it out" +      assert response["visibility"] == "direct" +    end + +    test "returns 400 when status is missing", %{conn: conn} do +      conn = post(conn, "/api/pleroma/admin/reports/test/respond") + +      assert json_response(conn, :bad_request) == "Invalid parameters" +    end + +    test "returns 404 when report id is invalid", %{conn: conn} do +      conn = +        post(conn, "/api/pleroma/admin/reports/test/respond", %{ +          "status" => "foo" +        }) + +      assert json_response(conn, :not_found) == "Not found" +    end +  end + +  describe "PUT /api/pleroma/admin/statuses/:id" do +    setup %{conn: conn} do +      admin = insert(:user, info: %{is_admin: true}) +      activity = insert(:note_activity) + +      %{conn: assign(conn, :user, admin), id: activity.id} +    end + +    test "toggle sensitive flag", %{conn: conn, id: id} do +      response = +        conn +        |> put("/api/pleroma/admin/statuses/#{id}", %{"sensitive" => "true"}) +        |> json_response(:ok) + +      assert response["sensitive"] + +      response = +        conn +        |> put("/api/pleroma/admin/statuses/#{id}", %{"sensitive" => "false"}) +        |> json_response(:ok) + +      refute response["sensitive"] +    end + +    test "change visibility flag", %{conn: conn, id: id} do +      response = +        conn +        |> put("/api/pleroma/admin/statuses/#{id}", %{"visibility" => "public"}) +        |> json_response(:ok) + +      assert response["visibility"] == "public" + +      response = +        conn +        |> put("/api/pleroma/admin/statuses/#{id}", %{"visibility" => "private"}) +        |> json_response(:ok) + +      assert response["visibility"] == "private" + +      response = +        conn +        |> put("/api/pleroma/admin/statuses/#{id}", %{"visibility" => "unlisted"}) +        |> json_response(:ok) + +      assert response["visibility"] == "unlisted" +    end + +    test "returns 400 when visibility is unknown", %{conn: conn, id: id} do +      conn = +        conn +        |> put("/api/pleroma/admin/statuses/#{id}", %{"visibility" => "test"}) + +      assert json_response(conn, :bad_request) == "Unsupported visibility" +    end +  end + +  describe "DELETE /api/pleroma/admin/statuses/:id" do +    setup %{conn: conn} do +      admin = insert(:user, info: %{is_admin: true}) +      activity = insert(:note_activity) + +      %{conn: assign(conn, :user, admin), id: activity.id} +    end + +    test "deletes status", %{conn: conn, id: id} do +      conn +      |> delete("/api/pleroma/admin/statuses/#{id}") +      |> json_response(:ok) + +      refute Activity.get_by_id(id) +    end + +    test "returns error when status is not exist", %{conn: conn} do +      conn = +        conn +        |> delete("/api/pleroma/admin/statuses/test") + +      assert json_response(conn, :bad_request) == "Could not delete" +    end +  end  end diff --git a/test/web/common_api/common_api_test.exs b/test/web/common_api/common_api_test.exs index 84744e5af..58305d09b 100644 --- a/test/web/common_api/common_api_test.exs +++ b/test/web/common_api/common_api_test.exs @@ -272,10 +272,41 @@ defmodule Pleroma.Web.CommonAPITest do                 data: %{                   "type" => "Flag",                   "content" => ^comment, -                 "object" => [^target_ap_id, ^activity_ap_id] +                 "object" => [^target_ap_id, ^activity_ap_id], +                 "state" => "open"                 }               } = flag_activity      end + +    test "updates report state" do +      [reporter, target_user] = insert_pair(:user) +      activity = insert(:note_activity, user: target_user) + +      {:ok, %Activity{id: report_id}} = +        CommonAPI.report(reporter, %{ +          "account_id" => target_user.id, +          "comment" => "I feel offended", +          "status_ids" => [activity.id] +        }) + +      {:ok, report} = CommonAPI.update_report_state(report_id, "resolved") + +      assert report.data["state"] == "resolved" +    end + +    test "does not update report state when state is unsupported" do +      [reporter, target_user] = insert_pair(:user) +      activity = insert(:note_activity, user: target_user) + +      {:ok, %Activity{id: report_id}} = +        CommonAPI.report(reporter, %{ +          "account_id" => target_user.id, +          "comment" => "I feel offended", +          "status_ids" => [activity.id] +        }) + +      assert CommonAPI.update_report_state(report_id, "test") == {:error, "Unsupported state"} +    end    end    describe "reblog muting" do @@ -290,14 +321,14 @@ defmodule Pleroma.Web.CommonAPITest do      test "add a reblog mute", %{muter: muter, muted: muted} do        {:ok, muter} = CommonAPI.hide_reblogs(muter, muted) -      assert Pleroma.User.showing_reblogs?(muter, muted) == false +      assert User.showing_reblogs?(muter, muted) == false      end      test "remove a reblog mute", %{muter: muter, muted: muted} do        {:ok, muter} = CommonAPI.hide_reblogs(muter, muted)        {:ok, muter} = CommonAPI.show_reblogs(muter, muted) -      assert Pleroma.User.showing_reblogs?(muter, muted) == true +      assert User.showing_reblogs?(muter, muted) == true      end    end  end diff --git a/test/web/mastodon_api/mastodon_api_controller_test.exs b/test/web/mastodon_api/mastodon_api_controller_test.exs index 40e7739e7..cbff141c8 100644 --- a/test/web/mastodon_api/mastodon_api_controller_test.exs +++ b/test/web/mastodon_api/mastodon_api_controller_test.exs @@ -446,7 +446,7 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPIControllerTest do    end    test "verify_credentials default scope unlisted", %{conn: conn} do -    user = insert(:user, %{info: %Pleroma.User.Info{default_scope: "unlisted"}}) +    user = insert(:user, %{info: %User.Info{default_scope: "unlisted"}})      conn =        conn @@ -1322,7 +1322,7 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPIControllerTest do    describe "locked accounts" do      test "/api/v1/follow_requests works" do -      user = insert(:user, %{info: %Pleroma.User.Info{locked: true}}) +      user = insert(:user, %{info: %User.Info{locked: true}})        other_user = insert(:user)        {:ok, _activity} = ActivityPub.follow(other_user, user) @@ -1367,7 +1367,7 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPIControllerTest do      end      test "verify_credentials", %{conn: conn} do -      user = insert(:user, %{info: %Pleroma.User.Info{default_scope: "private"}}) +      user = insert(:user, %{info: %User.Info{default_scope: "private"}})        conn =          conn @@ -1379,7 +1379,7 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPIControllerTest do      end      test "/api/v1/follow_requests/:id/reject works" do -      user = insert(:user, %{info: %Pleroma.User.Info{locked: true}}) +      user = insert(:user, %{info: %User.Info{locked: true}})        other_user = insert(:user)        {:ok, _activity} = ActivityPub.follow(other_user, user) @@ -2129,7 +2129,7 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPIControllerTest do          |> get("/api/v1/pleroma/accounts/#{user.id}/favourites")          |> json_response(:ok) -      assert length(anonymous_response) == 0 +      assert Enum.empty?(anonymous_response)      end      test "does not return others' favorited DM when user is not one of recipients", %{ @@ -2153,7 +2153,7 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPIControllerTest do          |> get("/api/v1/pleroma/accounts/#{user.id}/favourites")          |> json_response(:ok) -      assert length(response) == 0 +      assert Enum.empty?(response)      end      test "paginates favorites using since_id and max_id", %{ diff --git a/test/web/ostatus/ostatus_test.exs b/test/web/ostatus/ostatus_test.exs index 2916caf8d..f6be16862 100644 --- a/test/web/ostatus/ostatus_test.exs +++ b/test/web/ostatus/ostatus_test.exs @@ -355,7 +355,7 @@ defmodule Pleroma.Web.OStatusTest do        {:ok, user} = OStatus.find_or_make_user(uri) -      user = Pleroma.User.get_cached_by_id(user.id) +      user = User.get_cached_by_id(user.id)        assert user.name == "Constance Variable"        assert user.nickname == "lambadalambda@social.heldscal.la"        assert user.local == false @@ -374,7 +374,7 @@ defmodule Pleroma.Web.OStatusTest do        {:ok, user} = OStatus.find_or_make_user(uri)        assert user.info == -               %Pleroma.User.Info{ +               %User.Info{                   id: user.info.id,                   ap_enabled: false,                   background: %{}, @@ -407,7 +407,7 @@ defmodule Pleroma.Web.OStatusTest do        {:ok, user} = OStatus.find_or_make_user(uri)        old_name = user.name        old_bio = user.bio -      change = Ecto.Changeset.change(user, %{avatar: nil, bio: nil, old_name: nil}) +      change = Ecto.Changeset.change(user, %{avatar: nil, bio: nil, name: nil})        {:ok, user} = Repo.update(change)        refute user.avatar | 
