aboutsummaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
Diffstat (limited to 'test')
-rw-r--r--test/support/factory.ex54
-rw-r--r--test/web/admin_api/controllers/chat_controller_test.exs53
2 files changed, 107 insertions, 0 deletions
diff --git a/test/support/factory.ex b/test/support/factory.ex
index 486eda8da..61ca4587c 100644
--- a/test/support/factory.ex
+++ b/test/support/factory.ex
@@ -460,4 +460,58 @@ defmodule Pleroma.Factory do
phrase: "cofe"
}
end
+
+ def chat_factory(attrs \\ %{}) do
+ user = attrs[:user] || insert(:user)
+ recipient = attrs[:recipient] || insert(:user)
+
+ %Pleroma.Chat{
+ user_id: user.id,
+ recipient: recipient.ap_id
+ }
+ end
+
+ def chat_message_factory(attrs \\ %{}) do
+ text = sequence(:text, &"This is :moominmamma: chat message #{&1}")
+ chat = attrs[:chat] || insert(:chat)
+
+ data = %{
+ "type" => "ChatMessage",
+ "content" => text,
+ "id" => Pleroma.Web.ActivityPub.Utils.generate_object_id(),
+ "actor" => User.get_by_id(chat.user_id).ap_id,
+ "to" => [chat.recipient],
+ "published" => DateTime.utc_now() |> DateTime.to_iso8601()
+ }
+
+ %Pleroma.Object{
+ data: merge_attributes(data, Map.get(attrs, :data, %{}))
+ }
+ end
+
+ def chat_message_activity_factory(attrs \\ %{}) do
+ chat = attrs[:chat] || insert(:chat)
+ chat_message = attrs[:chat_message] || insert(:chat_message, chat: chat)
+
+ data_attrs = attrs[:data_attrs] || %{}
+ attrs = Map.drop(attrs, [:chat, :chat_message, :data_attrs])
+
+ data =
+ %{
+ "id" => Pleroma.Web.ActivityPub.Utils.generate_activity_id(),
+ "type" => "Create",
+ "actor" => chat_message.data["actor"],
+ "to" => chat_message.data["to"],
+ "object" => chat_message.data["id"],
+ "published" => DateTime.utc_now() |> DateTime.to_iso8601()
+ }
+ |> Map.merge(data_attrs)
+
+ %Pleroma.Activity{
+ data: data,
+ actor: data["actor"],
+ recipients: data["to"]
+ }
+ |> Map.merge(attrs)
+ end
end
diff --git a/test/web/admin_api/controllers/chat_controller_test.exs b/test/web/admin_api/controllers/chat_controller_test.exs
new file mode 100644
index 000000000..4527437af
--- /dev/null
+++ b/test/web/admin_api/controllers/chat_controller_test.exs
@@ -0,0 +1,53 @@
+# Pleroma: A lightweight social networking server
+# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>
+# SPDX-License-Identifier: AGPL-3.0-only
+
+defmodule Pleroma.Web.AdminAPI.ChatControllerTest do
+ use Pleroma.Web.ConnCase
+
+ import Pleroma.Factory
+
+ alias Pleroma.Activity
+ alias Pleroma.Config
+ alias Pleroma.ModerationLog
+ alias Pleroma.Repo
+
+ setup do
+ admin = insert(:user, is_admin: true)
+ token = insert(:oauth_admin_token, user: admin)
+
+ conn =
+ build_conn()
+ |> assign(:user, admin)
+ |> assign(:token, token)
+
+ {:ok, %{admin: admin, token: token, conn: conn}}
+ end
+
+ describe "DELETE /api/pleroma/admin/chats/:id/messages/:message_id" do
+ setup do
+ chat = insert(:chat)
+ message = insert(:chat_message_activity, chat: chat)
+ %{chat: chat, message: message}
+ end
+
+ test "deletes chat message", %{conn: conn, chat: chat, message: message, admin: admin} do
+ conn
+ |> delete("/api/pleroma/admin/chats/#{chat.id}/messages/#{message.id}")
+ |> json_response_and_validate_schema(:ok)
+
+ refute Activity.get_by_id(message.id)
+
+ log_entry = Repo.one(ModerationLog)
+
+ assert ModerationLog.get_log_entry_message(log_entry) ==
+ "@#{admin.nickname} deleted chat message ##{message.id}"
+ end
+
+ test "returns 404 when the chat message does not exist", %{conn: conn} do
+ conn = delete(conn, "/api/pleroma/admin/chats/test/messages/test")
+
+ assert json_response_and_validate_schema(conn, :not_found) == %{"error" => "Not found"}
+ end
+ end
+end