aboutsummaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorlain <lain@soykaf.club>2020-04-09 12:44:20 +0200
committerlain <lain@soykaf.club>2020-04-09 12:44:20 +0200
commit2e78686686f04726ad73749ee744b8a9df91ffb8 (patch)
tree625be9f9b1dda754ea1e59e839a61561d0ee4868 /test
parent3775683a04e9b819f88bfba533b755bbd5b3c2df (diff)
downloadpleroma-2e78686686f04726ad73749ee744b8a9df91ffb8.tar.gz
SideEffects: Handle ChatMessage creation.
Diffstat (limited to 'test')
-rw-r--r--test/chat_test.exs14
-rw-r--r--test/web/activity_pub/side_effects_test.exs26
2 files changed, 34 insertions, 6 deletions
diff --git a/test/chat_test.exs b/test/chat_test.exs
index ca9206802..bb2b46d51 100644
--- a/test/chat_test.exs
+++ b/test/chat_test.exs
@@ -14,7 +14,7 @@ defmodule Pleroma.ChatTest do
user = insert(:user)
other_user = insert(:user)
- {:ok, chat} = Chat.get_or_create(user.id, other_user.ap_id)
+ {:ok, chat} = Chat.bump_or_create(user.id, other_user.ap_id)
assert chat.id
end
@@ -23,19 +23,21 @@ defmodule Pleroma.ChatTest do
user = insert(:user)
other_user = insert(:user)
- {:ok, chat} = Chat.get_or_create(user.id, other_user.ap_id)
- {:ok, chat_two} = Chat.get_or_create(user.id, other_user.ap_id)
+ {:ok, chat} = Chat.bump_or_create(user.id, other_user.ap_id)
+ {:ok, chat_two} = Chat.bump_or_create(user.id, other_user.ap_id)
assert chat.id == chat_two.id
end
- test "a returning chat will have an updated `update_at` field" do
+ test "a returning chat will have an updated `update_at` field and an incremented unread count" do
user = insert(:user)
other_user = insert(:user)
- {:ok, chat} = Chat.get_or_create(user.id, other_user.ap_id)
+ {:ok, chat} = Chat.bump_or_create(user.id, other_user.ap_id)
+ assert chat.unread == 1
:timer.sleep(1500)
- {:ok, chat_two} = Chat.get_or_create(user.id, other_user.ap_id)
+ {:ok, chat_two} = Chat.bump_or_create(user.id, other_user.ap_id)
+ assert chat_two.unread == 2
assert chat.id == chat_two.id
assert chat.updated_at != chat_two.updated_at
diff --git a/test/web/activity_pub/side_effects_test.exs b/test/web/activity_pub/side_effects_test.exs
index b67bd14b3..5fd8372b5 100644
--- a/test/web/activity_pub/side_effects_test.exs
+++ b/test/web/activity_pub/side_effects_test.exs
@@ -5,6 +5,7 @@
defmodule Pleroma.Web.ActivityPub.SideEffectsTest do
use Pleroma.DataCase
+ alias Pleroma.Chat
alias Pleroma.Object
alias Pleroma.Web.ActivityPub.ActivityPub
alias Pleroma.Web.ActivityPub.Builder
@@ -31,4 +32,29 @@ defmodule Pleroma.Web.ActivityPub.SideEffectsTest do
assert user.ap_id in object.data["likes"]
end
end
+
+ describe "creation of ChatMessages" do
+ test "it creates a Chat for the local users and bumps the unread count" do
+ author = insert(:user, local: false)
+ recipient = insert(:user, local: true)
+
+ {:ok, chat_message_data, _meta} = Builder.chat_message(author, recipient.ap_id, "hey")
+ {:ok, chat_message_object} = Object.create(chat_message_data)
+
+ {:ok, create_activity_data, _meta} =
+ Builder.create(author, chat_message_object.data["id"], [recipient.ap_id])
+
+ {:ok, create_activity, _meta} = ActivityPub.persist(create_activity_data, local: false)
+
+ {:ok, _create_activity, _meta} = SideEffects.handle(create_activity)
+
+ # The remote user won't get a chat
+ chat = Chat.get(author.id, recipient.ap_id)
+ refute chat
+
+ # The local user will get a chat
+ chat = Chat.get(recipient.id, author.ap_id)
+ assert chat
+ end
+ end
end