diff options
author | lain <lain@soykaf.club> | 2023-06-11 13:17:12 +0000 |
---|---|---|
committer | lain <lain@soykaf.club> | 2023-06-11 13:17:12 +0000 |
commit | 4e6ea7cc9186e8a2a88943383f235e4c4e61fc45 (patch) | |
tree | 8e51b4a5484289e98a222e09724e9a77af83237d /test | |
parent | d93b47cf2ccf0666f70c4816acb45194e84a3865 (diff) | |
parent | 1fa196d8f7abfeccfcd911c74190866ad0950ca0 (diff) | |
download | pleroma-4e6ea7cc9186e8a2a88943383f235e4c4e61fc45.tar.gz pleroma-4e6ea7cc9186e8a2a88943383f235e4c4e61fc45.zip |
Merge branch 'tusooa/3054-banned-delete' into 'develop'
Fix deleting banned users' statuses
See merge request pleroma/pleroma!3889
Diffstat (limited to 'test')
-rw-r--r-- | test/pleroma/web/common_api_test.exs | 14 | ||||
-rw-r--r-- | test/pleroma/web/mastodon_api/controllers/status_controller_test.exs | 21 |
2 files changed, 35 insertions, 0 deletions
diff --git a/test/pleroma/web/common_api_test.exs b/test/pleroma/web/common_api_test.exs index 3112d831b..968e11a14 100644 --- a/test/pleroma/web/common_api_test.exs +++ b/test/pleroma/web/common_api_test.exs @@ -393,6 +393,20 @@ defmodule Pleroma.Web.CommonAPITest do refute Activity.get_by_id(post.id) end + + test "it allows privileged users to delete banned user's posts" do + clear_config([:instance, :moderator_privileges], [:messages_delete]) + user = insert(:user) + moderator = insert(:user, is_moderator: true) + + {:ok, post} = CommonAPI.post(user, %{status: "namu amida butsu"}) + User.set_activation(user, false) + + assert {:ok, delete} = CommonAPI.delete(post.id, moderator) + assert delete.local + + refute Activity.get_by_id(post.id) + end end test "favoriting race condition" do diff --git a/test/pleroma/web/mastodon_api/controllers/status_controller_test.exs b/test/pleroma/web/mastodon_api/controllers/status_controller_test.exs index 1e8979127..4f434cb69 100644 --- a/test/pleroma/web/mastodon_api/controllers/status_controller_test.exs +++ b/test/pleroma/web/mastodon_api/controllers/status_controller_test.exs @@ -1018,6 +1018,27 @@ defmodule Pleroma.Web.MastodonAPI.StatusControllerTest do refute Activity.get_by_id(activity.id) end + + test "when you're privileged and the user is banned", %{conn: conn} do + clear_config([:instance, :moderator_privileges], [:messages_delete]) + posting_user = insert(:user, is_active: false) + refute posting_user.is_active + activity = insert(:note_activity, user: posting_user) + user = insert(:user, is_moderator: true) + + res_conn = + conn + |> assign(:user, user) + |> assign(:token, insert(:oauth_token, user: user, scopes: ["write:statuses"])) + |> delete("/api/v1/statuses/#{activity.id}") + + assert %{} = json_response_and_validate_schema(res_conn, 200) + + assert ModerationLog |> Repo.one() |> ModerationLog.get_log_entry_message() == + "@#{user.nickname} deleted status ##{activity.id}" + + refute Activity.get_by_id(activity.id) + end end describe "reblogging" do |