diff options
Diffstat (limited to 'test/web')
| -rw-r--r-- | test/web/activity_pub/activity_pub_test.exs | 35 | ||||
| -rw-r--r-- | test/web/activity_pub/transmogrifier_test.exs | 233 | ||||
| -rw-r--r-- | test/web/common_api/common_api_test.exs | 13 | ||||
| -rw-r--r-- | test/web/common_api/common_api_utils_test.exs | 5 | ||||
| -rw-r--r-- | test/web/mastodon_api/list_view_test.exs | 19 | ||||
| -rw-r--r-- | test/web/mastodon_api/mastodon_api_controller_test.exs | 119 | ||||
| -rw-r--r-- | test/web/ostatus/ostatus_test.exs | 24 | ||||
| -rw-r--r-- | test/web/twitter_api/twitter_api_controller_test.exs | 79 | ||||
| -rw-r--r-- | test/web/twitter_api/twitter_api_test.exs | 4 | ||||
| -rw-r--r-- | test/web/twitter_api/views/notification_view_test.exs | 2 | ||||
| -rw-r--r-- | test/web/twitter_api/views/user_view_test.exs | 2 | 
11 files changed, 523 insertions, 12 deletions
| diff --git a/test/web/activity_pub/activity_pub_test.exs b/test/web/activity_pub/activity_pub_test.exs index 9adce84b5..081c202b1 100644 --- a/test/web/activity_pub/activity_pub_test.exs +++ b/test/web/activity_pub/activity_pub_test.exs @@ -425,7 +425,40 @@ defmodule Pleroma.Web.ActivityPub.ActivityPubTest do        assert activity.data["type"] == "Undo"        assert activity.data["actor"] == follower.ap_id -      assert activity.data["object"] == follow_activity.data["id"] + +      assert is_map(activity.data["object"]) +      assert activity.data["object"]["type"] == "Follow" +      assert activity.data["object"]["object"] == followed.ap_id +      assert activity.data["object"]["id"] == follow_activity.data["id"] +    end +  end + +  describe "blocking / unblocking" do +    test "creates a block activity" do +      blocker = insert(:user) +      blocked = insert(:user) + +      {:ok, activity} = ActivityPub.block(blocker, blocked) + +      assert activity.data["type"] == "Block" +      assert activity.data["actor"] == blocker.ap_id +      assert activity.data["object"] == blocked.ap_id +    end + +    test "creates an undo activity for the last block" do +      blocker = insert(:user) +      blocked = insert(:user) + +      {:ok, block_activity} = ActivityPub.block(blocker, blocked) +      {:ok, activity} = ActivityPub.unblock(blocker, blocked) + +      assert activity.data["type"] == "Undo" +      assert activity.data["actor"] == blocker.ap_id + +      assert is_map(activity.data["object"]) +      assert activity.data["object"]["type"] == "Block" +      assert activity.data["object"]["object"] == blocked.ap_id +      assert activity.data["object"]["id"] == block_activity.data["id"]      end    end diff --git a/test/web/activity_pub/transmogrifier_test.exs b/test/web/activity_pub/transmogrifier_test.exs index a0af75a69..384844095 100644 --- a/test/web/activity_pub/transmogrifier_test.exs +++ b/test/web/activity_pub/transmogrifier_test.exs @@ -2,13 +2,12 @@ defmodule Pleroma.Web.ActivityPub.TransmogrifierTest do    use Pleroma.DataCase    alias Pleroma.Web.ActivityPub.Transmogrifier    alias Pleroma.Web.ActivityPub.Utils +  alias Pleroma.Web.ActivityPub.ActivityPub    alias Pleroma.Web.OStatus    alias Pleroma.Activity    alias Pleroma.User    alias Pleroma.Repo    alias Pleroma.Web.Websub.WebsubClientSubscription -  alias Pleroma.Web.Websub.WebsubServerSubscription -  import Ecto.Query    import Pleroma.Factory    alias Pleroma.Web.CommonAPI @@ -283,7 +282,7 @@ defmodule Pleroma.Web.ActivityPub.TransmogrifierTest do          |> Map.put("object", object)          |> Map.put("actor", activity.data["actor"]) -      {:ok, %Activity{data: data, local: false}} = Transmogrifier.handle_incoming(data) +      {:ok, %Activity{local: false}} = Transmogrifier.handle_incoming(data)        refute Repo.get(Activity, activity.id)      end @@ -315,6 +314,234 @@ defmodule Pleroma.Web.ActivityPub.TransmogrifierTest do        assert data["object"]["id"] ==                 "http://mastodon.example.org/users/admin/statuses/99542391527669785/activity"      end + +    test "it works for incomming unfollows with an existing follow" do +      user = insert(:user) + +      follow_data = +        File.read!("test/fixtures/mastodon-follow-activity.json") +        |> Poison.decode!() +        |> Map.put("object", user.ap_id) + +      {:ok, %Activity{data: _, local: false}} = Transmogrifier.handle_incoming(follow_data) + +      data = +        File.read!("test/fixtures/mastodon-unfollow-activity.json") +        |> Poison.decode!() +        |> Map.put("object", follow_data) + +      {:ok, %Activity{data: data, local: false}} = Transmogrifier.handle_incoming(data) + +      assert data["type"] == "Undo" +      assert data["object"]["type"] == "Follow" +      assert data["object"]["object"] == user.ap_id +      assert data["actor"] == "http://mastodon.example.org/users/admin" + +      refute User.following?(User.get_by_ap_id(data["actor"]), user) +    end + +    test "it works for incoming blocks" do +      user = insert(:user) + +      data = +        File.read!("test/fixtures/mastodon-block-activity.json") +        |> Poison.decode!() +        |> Map.put("object", user.ap_id) + +      {:ok, %Activity{data: data, local: false}} = Transmogrifier.handle_incoming(data) + +      assert data["type"] == "Block" +      assert data["object"] == user.ap_id +      assert data["actor"] == "http://mastodon.example.org/users/admin" + +      blocker = User.get_by_ap_id(data["actor"]) + +      assert User.blocks?(blocker, user) +    end + +    test "it works for incoming unblocks with an existing block" do +      user = insert(:user) + +      block_data = +        File.read!("test/fixtures/mastodon-block-activity.json") +        |> Poison.decode!() +        |> Map.put("object", user.ap_id) + +      {:ok, %Activity{data: _, local: false}} = Transmogrifier.handle_incoming(block_data) + +      data = +        File.read!("test/fixtures/mastodon-unblock-activity.json") +        |> Poison.decode!() +        |> Map.put("object", block_data) + +      {:ok, %Activity{data: data, local: false}} = Transmogrifier.handle_incoming(data) +      assert data["type"] == "Undo" +      assert data["object"]["type"] == "Block" +      assert data["object"]["object"] == user.ap_id +      assert data["actor"] == "http://mastodon.example.org/users/admin" + +      blocker = User.get_by_ap_id(data["actor"]) + +      refute User.blocks?(blocker, user) +    end + +    test "it works for incoming accepts which were pre-accepted" do +      follower = insert(:user) +      followed = insert(:user) + +      {:ok, follower} = User.follow(follower, followed) +      assert User.following?(follower, followed) == true + +      {:ok, follow_activity} = ActivityPub.follow(follower, followed) + +      accept_data = +        File.read!("test/fixtures/mastodon-accept-activity.json") +        |> Poison.decode!() +        |> Map.put("actor", followed.ap_id) + +      object = +        accept_data["object"] +        |> Map.put("actor", follower.ap_id) +        |> Map.put("id", follow_activity.data["id"]) + +      accept_data = Map.put(accept_data, "object", object) + +      {:ok, activity} = Transmogrifier.handle_incoming(accept_data) +      refute activity.local + +      assert activity.data["object"] == follow_activity.data["id"] + +      follower = Repo.get(User, follower.id) + +      assert User.following?(follower, followed) == true +    end + +    test "it works for incoming accepts which were orphaned" do +      follower = insert(:user) +      followed = insert(:user, %{info: %{"locked" => true}}) + +      {:ok, follow_activity} = ActivityPub.follow(follower, followed) + +      accept_data = +        File.read!("test/fixtures/mastodon-accept-activity.json") +        |> Poison.decode!() +        |> Map.put("actor", followed.ap_id) + +      accept_data = +        Map.put(accept_data, "object", Map.put(accept_data["object"], "actor", follower.ap_id)) + +      {:ok, activity} = Transmogrifier.handle_incoming(accept_data) +      assert activity.data["object"] == follow_activity.data["id"] + +      follower = Repo.get(User, follower.id) + +      assert User.following?(follower, followed) == true +    end + +    test "it works for incoming accepts which are referenced by IRI only" do +      follower = insert(:user) +      followed = insert(:user, %{info: %{"locked" => true}}) + +      {:ok, follow_activity} = ActivityPub.follow(follower, followed) + +      accept_data = +        File.read!("test/fixtures/mastodon-accept-activity.json") +        |> Poison.decode!() +        |> Map.put("actor", followed.ap_id) +        |> Map.put("object", follow_activity.data["id"]) + +      {:ok, activity} = Transmogrifier.handle_incoming(accept_data) +      assert activity.data["object"] == follow_activity.data["id"] + +      follower = Repo.get(User, follower.id) + +      assert User.following?(follower, followed) == true +    end + +    test "it fails for incoming accepts which cannot be correlated" do +      follower = insert(:user) +      followed = insert(:user, %{info: %{"locked" => true}}) + +      accept_data = +        File.read!("test/fixtures/mastodon-accept-activity.json") +        |> Poison.decode!() +        |> Map.put("actor", followed.ap_id) + +      accept_data = +        Map.put(accept_data, "object", Map.put(accept_data["object"], "actor", follower.ap_id)) + +      :error = Transmogrifier.handle_incoming(accept_data) + +      follower = Repo.get(User, follower.id) + +      refute User.following?(follower, followed) == true +    end + +    test "it fails for incoming rejects which cannot be correlated" do +      follower = insert(:user) +      followed = insert(:user, %{info: %{"locked" => true}}) + +      accept_data = +        File.read!("test/fixtures/mastodon-reject-activity.json") +        |> Poison.decode!() +        |> Map.put("actor", followed.ap_id) + +      accept_data = +        Map.put(accept_data, "object", Map.put(accept_data["object"], "actor", follower.ap_id)) + +      :error = Transmogrifier.handle_incoming(accept_data) + +      follower = Repo.get(User, follower.id) + +      refute User.following?(follower, followed) == true +    end + +    test "it works for incoming rejects which are orphaned" do +      follower = insert(:user) +      followed = insert(:user, %{info: %{"locked" => true}}) + +      {:ok, follower} = User.follow(follower, followed) +      {:ok, _follow_activity} = ActivityPub.follow(follower, followed) + +      assert User.following?(follower, followed) == true + +      reject_data = +        File.read!("test/fixtures/mastodon-reject-activity.json") +        |> Poison.decode!() +        |> Map.put("actor", followed.ap_id) + +      reject_data = +        Map.put(reject_data, "object", Map.put(reject_data["object"], "actor", follower.ap_id)) + +      {:ok, activity} = Transmogrifier.handle_incoming(reject_data) +      refute activity.local + +      follower = Repo.get(User, follower.id) + +      assert User.following?(follower, followed) == false +    end + +    test "it works for incoming rejects which are referenced by IRI only" do +      follower = insert(:user) +      followed = insert(:user, %{info: %{"locked" => true}}) + +      {:ok, follower} = User.follow(follower, followed) +      {:ok, follow_activity} = ActivityPub.follow(follower, followed) + +      assert User.following?(follower, followed) == true + +      reject_data = +        File.read!("test/fixtures/mastodon-reject-activity.json") +        |> Poison.decode!() +        |> Map.put("actor", followed.ap_id) +        |> Map.put("object", follow_activity.data["id"]) + +      {:ok, %Activity{data: _}} = Transmogrifier.handle_incoming(reject_data) + +      follower = Repo.get(User, follower.id) + +      assert User.following?(follower, followed) == false +    end    end    describe "prepare outgoing" do diff --git a/test/web/common_api/common_api_test.exs b/test/web/common_api/common_api_test.exs new file mode 100644 index 000000000..a5da271b3 --- /dev/null +++ b/test/web/common_api/common_api_test.exs @@ -0,0 +1,13 @@ +defmodule Pleroma.Web.CommonAPI.Test do +  use Pleroma.DataCase +  alias Pleroma.Web.CommonAPI + +  import Pleroma.Factory + +  test "it de-duplicates tags" do +    user = insert(:user) +    {:ok, activity} = CommonAPI.post(user, %{"status" => "#2hu #2HU"}) + +    assert activity.data["object"]["tag"] == ["2hu"] +  end +end diff --git a/test/web/common_api/common_api_utils_test.exs b/test/web/common_api/common_api_utils_test.exs index 23cce471f..f39472ee3 100644 --- a/test/web/common_api/common_api_utils_test.exs +++ b/test/web/common_api/common_api_utils_test.exs @@ -21,13 +21,12 @@ defmodule Pleroma.Web.CommonAPI.UtilsTest do      test "incorrect password given" do        {:ok, user} = UserBuilder.insert() -      assert Utils.confirm_current_password(user, %{"password" => ""}) == -               {:error, "Invalid password."} +      assert Utils.confirm_current_password(user, "") == {:error, "Invalid password."}      end      test "correct password given" do        {:ok, user} = UserBuilder.insert() -      assert Utils.confirm_current_password(user, %{"password" => "test"}) == {:ok, user} +      assert Utils.confirm_current_password(user, "test") == {:ok, user}      end    end  end diff --git a/test/web/mastodon_api/list_view_test.exs b/test/web/mastodon_api/list_view_test.exs new file mode 100644 index 000000000..5e36872ed --- /dev/null +++ b/test/web/mastodon_api/list_view_test.exs @@ -0,0 +1,19 @@ +defmodule Pleroma.Web.MastodonAPI.ListViewTest do +  use Pleroma.DataCase +  import Pleroma.Factory +  alias Pleroma.Web.MastodonAPI.ListView +  alias Pleroma.List + +  test "Represent a list" do +    user = insert(:user) +    title = "mortal enemies" +    {:ok, list} = Pleroma.List.create(title, user) + +    expected = %{ +      id: to_string(list.id), +      title: title +    } + +    assert expected == ListView.render("list.json", %{list: list}) +  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 72f948230..553581be4 100644 --- a/test/web/mastodon_api/mastodon_api_controller_test.exs +++ b/test/web/mastodon_api/mastodon_api_controller_test.exs @@ -229,6 +229,125 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPIControllerTest do      end    end +  describe "lists" do +    test "creating a list", %{conn: conn} do +      user = insert(:user) + +      conn = +        conn +        |> assign(:user, user) +        |> post("/api/v1/lists", %{"title" => "cuties"}) + +      assert %{"title" => title} = json_response(conn, 200) +      assert title == "cuties" +    end + +    test "adding users to a list", %{conn: conn} do +      user = insert(:user) +      other_user = insert(:user) +      {:ok, list} = Pleroma.List.create("name", user) + +      conn = +        conn +        |> assign(:user, user) +        |> post("/api/v1/lists/#{list.id}/accounts", %{"account_ids" => [other_user.id]}) + +      assert %{} == json_response(conn, 200) +      %Pleroma.List{following: following} = Pleroma.List.get(list.id, user) +      assert following == [other_user.follower_address] +    end + +    test "removing users from a list", %{conn: conn} do +      user = insert(:user) +      other_user = insert(:user) +      third_user = insert(:user) +      {:ok, list} = Pleroma.List.create("name", user) +      {:ok, list} = Pleroma.List.follow(list, other_user) +      {:ok, list} = Pleroma.List.follow(list, third_user) + +      conn = +        conn +        |> assign(:user, user) +        |> delete("/api/v1/lists/#{list.id}/accounts", %{"account_ids" => [other_user.id]}) + +      assert %{} == json_response(conn, 200) +      %Pleroma.List{following: following} = Pleroma.List.get(list.id, user) +      assert following == [third_user.follower_address] +    end + +    test "listing users in a list", %{conn: conn} do +      user = insert(:user) +      other_user = insert(:user) +      {:ok, list} = Pleroma.List.create("name", user) +      {:ok, list} = Pleroma.List.follow(list, other_user) + +      conn = +        conn +        |> assign(:user, user) +        |> get("/api/v1/lists/#{list.id}/accounts", %{"account_ids" => [other_user.id]}) + +      assert [%{"id" => id}] = json_response(conn, 200) +      assert id == to_string(other_user.id) +    end + +    test "retrieving a list", %{conn: conn} do +      user = insert(:user) +      {:ok, list} = Pleroma.List.create("name", user) + +      conn = +        conn +        |> assign(:user, user) +        |> get("/api/v1/lists/#{list.id}") + +      assert %{"id" => id} = json_response(conn, 200) +      assert id == to_string(list.id) +    end + +    test "renaming a list", %{conn: conn} do +      user = insert(:user) +      {:ok, list} = Pleroma.List.create("name", user) + +      conn = +        conn +        |> assign(:user, user) +        |> put("/api/v1/lists/#{list.id}", %{"title" => "newname"}) + +      assert %{"title" => name} = json_response(conn, 200) +      assert name == "newname" +    end + +    test "deleting a list", %{conn: conn} do +      user = insert(:user) +      {:ok, list} = Pleroma.List.create("name", user) + +      conn = +        conn +        |> assign(:user, user) +        |> delete("/api/v1/lists/#{list.id}") + +      assert %{} = json_response(conn, 200) +      assert is_nil(Repo.get(Pleroma.List, list.id)) +    end + +    test "list timeline", %{conn: conn} do +      user = insert(:user) +      other_user = insert(:user) +      {:ok, _activity_one} = TwitterAPI.create_status(user, %{"status" => "Marisa is cute."}) +      {:ok, activity_two} = TwitterAPI.create_status(other_user, %{"status" => "Marisa is cute."}) +      {:ok, list} = Pleroma.List.create("name", user) +      {:ok, list} = Pleroma.List.follow(list, other_user) + +      conn = +        conn +        |> assign(:user, user) +        |> get("/api/v1/timelines/list/#{list.id}") + +      assert [%{"id" => id}] = json_response(conn, 200) + +      assert id == to_string(activity_two.id) +    end +  end +    describe "notifications" do      test "list of notifications", %{conn: conn} do        user = insert(:user) diff --git a/test/web/ostatus/ostatus_test.exs b/test/web/ostatus/ostatus_test.exs index 3e7cf0155..f095e41dd 100644 --- a/test/web/ostatus/ostatus_test.exs +++ b/test/web/ostatus/ostatus_test.exs @@ -278,6 +278,30 @@ defmodule Pleroma.Web.OStatusTest do      assert User.following?(follower, followed)    end +  test "handle incoming unfollows with existing follow" do +    incoming_follow = File.read!("test/fixtures/follow.xml") +    {:ok, [_activity]} = OStatus.handle_incoming(incoming_follow) + +    incoming = File.read!("test/fixtures/unfollow.xml") +    {:ok, [activity]} = OStatus.handle_incoming(incoming) + +    assert activity.data["type"] == "Undo" + +    assert activity.data["id"] == +             "undo:tag:social.heldscal.la,2017-05-07:subscription:23211:person:44803:2017-05-07T09:54:48+00:00" + +    assert activity.data["actor"] == "https://social.heldscal.la/user/23211" +    assert is_map(activity.data["object"]) +    assert activity.data["object"]["type"] == "Follow" +    assert activity.data["object"]["object"] == "https://pawoo.net/users/pekorino" +    refute activity.local + +    follower = User.get_by_ap_id(activity.data["actor"]) +    followed = User.get_by_ap_id(activity.data["object"]["object"]) + +    refute User.following?(follower, followed) +  end +    describe "new remote user creation" do      test "returns local users" do        local_user = insert(:user) diff --git a/test/web/twitter_api/twitter_api_controller_test.exs b/test/web/twitter_api/twitter_api_controller_test.exs index 02aba0bc8..c2ea41aa3 100644 --- a/test/web/twitter_api/twitter_api_controller_test.exs +++ b/test/web/twitter_api/twitter_api_controller_test.exs @@ -8,6 +8,7 @@ defmodule Pleroma.Web.TwitterAPI.ControllerTest do    alias Pleroma.Web.TwitterAPI.NotificationView    alias Pleroma.Web.CommonAPI    alias Pleroma.Web.TwitterAPI.TwitterAPI +  alias Comeonin.Pbkdf2    import Pleroma.Factory @@ -443,7 +444,7 @@ defmodule Pleroma.Web.TwitterAPI.ControllerTest do      test "with credentials", %{conn: conn, user: current_user} do        blocked = insert(:user) -      {:ok, current_user} = User.block(current_user, blocked) +      {:ok, current_user, blocked} = TwitterAPI.block(current_user, %{"user_id" => blocked.id})        assert User.blocks?(current_user, blocked)        conn = @@ -801,6 +802,82 @@ defmodule Pleroma.Web.TwitterAPI.ControllerTest do      assert user.bio == "Hello,<br>World! I<br> am a test."    end +  describe "POST /api/pleroma/change_password" do +    setup [:valid_user] + +    test "without credentials", %{conn: conn} do +      conn = post(conn, "/api/pleroma/change_password") +      assert json_response(conn, 403) == %{"error" => "Invalid credentials."} +    end + +    test "with credentials and invalid password", %{conn: conn, user: current_user} do +      conn = +        conn +        |> with_credentials(current_user.nickname, "test") +        |> post("/api/pleroma/change_password", %{ +          "password" => "hi", +          "new_password" => "newpass", +          "new_password_confirmation" => "newpass" +        }) + +      assert json_response(conn, 200) == %{"error" => "Invalid password."} +    end + +    test "with credentials, valid password and new password and confirmation not matching", %{ +      conn: conn, +      user: current_user +    } do +      conn = +        conn +        |> with_credentials(current_user.nickname, "test") +        |> post("/api/pleroma/change_password", %{ +          "password" => "test", +          "new_password" => "newpass", +          "new_password_confirmation" => "notnewpass" +        }) + +      assert json_response(conn, 200) == %{ +               "error" => "New password does not match confirmation." +             } +    end + +    test "with credentials, valid password and invalid new password", %{ +      conn: conn, +      user: current_user +    } do +      conn = +        conn +        |> with_credentials(current_user.nickname, "test") +        |> post("/api/pleroma/change_password", %{ +          "password" => "test", +          "new_password" => "", +          "new_password_confirmation" => "" +        }) + +      assert json_response(conn, 200) == %{ +               "error" => "New password can't be blank." +             } +    end + +    test "with credentials, valid password and matching new password and confirmation", %{ +      conn: conn, +      user: current_user +    } do +      conn = +        conn +        |> with_credentials(current_user.nickname, "test") +        |> post("/api/pleroma/change_password", %{ +          "password" => "test", +          "new_password" => "newpass", +          "new_password_confirmation" => "newpass" +        }) + +      assert json_response(conn, 200) == %{"status" => "success"} +      fetched_user = Repo.get(User, current_user.id) +      assert Pbkdf2.checkpw("newpass", fetched_user.password_hash) == true +    end +  end +    describe "POST /api/pleroma/delete_account" do      setup [:valid_user] diff --git a/test/web/twitter_api/twitter_api_test.exs b/test/web/twitter_api/twitter_api_test.exs index af565c0e5..4716abb84 100644 --- a/test/web/twitter_api/twitter_api_test.exs +++ b/test/web/twitter_api/twitter_api_test.exs @@ -166,7 +166,7 @@ defmodule Pleroma.Web.TwitterAPI.TwitterAPITest do    test "Unblock another user using user_id" do      unblocked = insert(:user)      user = insert(:user) -    User.block(user, unblocked) +    {:ok, user, _unblocked} = TwitterAPI.block(user, %{"user_id" => unblocked.id})      {:ok, user, _unblocked} = TwitterAPI.unblock(user, %{"user_id" => unblocked.id})      assert user.info["blocks"] == [] @@ -175,7 +175,7 @@ defmodule Pleroma.Web.TwitterAPI.TwitterAPITest do    test "Unblock another user using screen_name" do      unblocked = insert(:user)      user = insert(:user) -    User.block(user, unblocked) +    {:ok, user, _unblocked} = TwitterAPI.block(user, %{"screen_name" => unblocked.nickname})      {:ok, user, _unblocked} = TwitterAPI.unblock(user, %{"screen_name" => unblocked.nickname})      assert user.info["blocks"] == [] diff --git a/test/web/twitter_api/views/notification_view_test.exs b/test/web/twitter_api/views/notification_view_test.exs index e3b140657..79eafda7d 100644 --- a/test/web/twitter_api/views/notification_view_test.exs +++ b/test/web/twitter_api/views/notification_view_test.exs @@ -24,7 +24,7 @@ defmodule Pleroma.Web.TwitterAPI.NotificationViewTest do      {:ok, follower} = User.follow(follower, user)      {:ok, activity} = ActivityPub.follow(follower, user) -    Cachex.set(:user_cache, "user_info:#{user.id}", User.user_info(Repo.get!(User, user.id))) +    Cachex.put(:user_cache, "user_info:#{user.id}", User.user_info(Repo.get!(User, user.id)))      [follow_notif] = Notification.for_user(user)      represented = %{ diff --git a/test/web/twitter_api/views/user_view_test.exs b/test/web/twitter_api/views/user_view_test.exs index dd55c0b7e..9f8bf4cdc 100644 --- a/test/web/twitter_api/views/user_view_test.exs +++ b/test/web/twitter_api/views/user_view_test.exs @@ -31,7 +31,7 @@ defmodule Pleroma.Web.TwitterAPI.UserViewTest do      User.follow(second_follower, user)      User.follow(user, follower)      {:ok, user} = User.update_follower_count(user) -    Cachex.set(:user_cache, "user_info:#{user.id}", User.user_info(Repo.get!(User, user.id))) +    Cachex.put(:user_cache, "user_info:#{user.id}", User.user_info(Repo.get!(User, user.id)))      image = "http://localhost:4001/images/avi.png"      banner = "http://localhost:4001/images/banner.png" | 
