diff options
| -rw-r--r-- | lib/pleroma/web/common_api/common_api.ex | 1 | ||||
| -rw-r--r-- | test/web/common_api/common_api_test.exs | 23 | 
2 files changed, 24 insertions, 0 deletions
| diff --git a/lib/pleroma/web/common_api/common_api.ex b/lib/pleroma/web/common_api/common_api.ex index 7ec6aa0ea..2902905fd 100644 --- a/lib/pleroma/web/common_api/common_api.ex +++ b/lib/pleroma/web/common_api/common_api.ex @@ -14,6 +14,7 @@ defmodule Pleroma.Web.CommonAPI do      with %Activity{data: %{"object" => %{"id" => object_id}}} <- Repo.get(Activity, activity_id),           %Object{} = object <- Object.normalize(object_id),           true <- user.info.is_moderator || user.ap_id == object.data["actor"], +         {:ok, _} <- unpin(activity_id, user),           {:ok, delete} <- ActivityPub.delete(object) do        {:ok, delete}      end diff --git a/test/web/common_api/common_api_test.exs b/test/web/common_api/common_api_test.exs index eb69ea4b2..9ac805f24 100644 --- a/test/web/common_api/common_api_test.exs +++ b/test/web/common_api/common_api_test.exs @@ -109,6 +109,11 @@ defmodule Pleroma.Web.CommonAPI.Test do      test "pin status", %{user: user, activity: activity} do        assert {:ok, ^activity} = CommonAPI.pin(activity.id, user) + +      id = activity.id +      user = refresh_record(user) + +      assert %User{info: %{pinned_activities: [^id]}} = user      end      test "only self-authored can be pinned", %{activity: activity} do @@ -131,7 +136,25 @@ defmodule Pleroma.Web.CommonAPI.Test do      test "unpin status", %{user: user, activity: activity} do        {:ok, activity} = CommonAPI.pin(activity.id, user) +      user = refresh_record(user) +        assert {:ok, ^activity} = CommonAPI.unpin(activity.id, user) + +      user = refresh_record(user) + +      assert %User{info: %{pinned_activities: []}} = user +    end + +    test "should unpin when deleting a status", %{user: user, activity: activity} do +      {:ok, activity} = CommonAPI.pin(activity.id, user) + +      user = refresh_record(user) + +      assert {:ok, _} = CommonAPI.delete(activity.id, user) + +      user = refresh_record(user) + +      assert %User{info: %{pinned_activities: []}} = user      end    end  end | 
