aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorlain <lain@soykaf.club>2020-05-12 13:23:09 +0200
committerlain <lain@soykaf.club>2020-05-12 13:23:09 +0200
commitec72cba43ec4f45faadf1b06a6d014cd4136707e (patch)
tree291b918ffe881c15b981d02a4805b348d3706249
parentdcb5cda324c5a8233c100e49d0ad137a5daffd71 (diff)
downloadpleroma-ec72cba43ec4f45faadf1b06a6d014cd4136707e.tar.gz
Chat Controller: Add basic error handling.
-rw-r--r--lib/pleroma/web/pleroma_api/controllers/chat_controller.ex5
-rw-r--r--test/web/pleroma_api/controllers/chat_controller_test.exs12
2 files changed, 15 insertions, 2 deletions
diff --git a/lib/pleroma/web/pleroma_api/controllers/chat_controller.ex b/lib/pleroma/web/pleroma_api/controllers/chat_controller.ex
index 8eed88752..4ce3e7419 100644
--- a/lib/pleroma/web/pleroma_api/controllers/chat_controller.ex
+++ b/lib/pleroma/web/pleroma_api/controllers/chat_controller.ex
@@ -18,8 +18,7 @@ defmodule Pleroma.Web.PleromaAPI.ChatController do
import Ecto.Query
import Pleroma.Web.ActivityPub.ObjectValidator, only: [stringify_keys: 1]
- # TODO
- # - Error handling
+ action_fallback(Pleroma.Web.MastodonAPI.FallbackController)
plug(
OAuthScopesPlug,
@@ -53,6 +52,8 @@ defmodule Pleroma.Web.PleromaAPI.ChatController do
conn
|> put_view(ChatMessageView)
|> render("show.json", for: user, object: message, chat: chat)
+ else
+ _e -> {:error, :could_not_delete}
end
end
diff --git a/test/web/pleroma_api/controllers/chat_controller_test.exs b/test/web/pleroma_api/controllers/chat_controller_test.exs
index 86ccbb117..75d4903ed 100644
--- a/test/web/pleroma_api/controllers/chat_controller_test.exs
+++ b/test/web/pleroma_api/controllers/chat_controller_test.exs
@@ -88,6 +88,8 @@ defmodule Pleroma.Web.PleromaAPI.ChatControllerTest do
{:ok, message} =
CommonAPI.post_chat_message(user, recipient, "Hello darkness my old friend")
+ {:ok, other_message} = CommonAPI.post_chat_message(recipient, user, "nico nico ni")
+
object = Object.normalize(message, false)
chat = Chat.get(user.id, recipient.ap_id)
@@ -99,6 +101,16 @@ defmodule Pleroma.Web.PleromaAPI.ChatControllerTest do
|> json_response_and_validate_schema(200)
assert result["id"] == to_string(object.id)
+
+ object = Object.normalize(other_message, false)
+
+ result =
+ conn
+ |> put_req_header("content-type", "application/json")
+ |> delete("/api/v1/pleroma/chats/#{chat.id}/messages/#{object.id}")
+ |> json_response(400)
+
+ assert result == %{"error" => "could_not_delete"}
end
end