1 # Pleroma: A lightweight social networking server
2 # Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>
3 # SPDX-License-Identifier: AGPL-3.0-only
4 defmodule Pleroma.Web.PleromaAPI.ChatControllerTest do
5 use Pleroma.Web.ConnCase, async: true
8 alias Pleroma.Web.CommonAPI
10 import Pleroma.Factory
12 describe "POST /api/v1/pleroma/chats/:id/messages" do
13 setup do: oauth_access(["write:statuses"])
15 test "it posts a message to the chat", %{conn: conn, user: user} do
16 other_user = insert(:user)
18 {:ok, chat} = Chat.get_or_create(user.id, other_user.ap_id)
22 |> put_req_header("content-type", "application/json")
23 |> post("/api/v1/pleroma/chats/#{chat.id}/messages", %{"content" => "Hallo!!"})
24 |> json_response_and_validate_schema(200)
26 assert result["content"] == "Hallo!!"
27 assert result["chat_id"] == chat.id |> to_string()
31 describe "GET /api/v1/pleroma/chats/:id/messages" do
32 setup do: oauth_access(["read:statuses"])
34 test "it paginates", %{conn: conn, user: user} do
35 recipient = insert(:user)
37 Enum.each(1..30, fn _ ->
38 {:ok, _} = CommonAPI.post_chat_message(user, recipient, "hey")
41 chat = Chat.get(user.id, recipient.ap_id)
45 |> get("/api/v1/pleroma/chats/#{chat.id}/messages")
46 |> json_response_and_validate_schema(200)
48 assert length(result) == 20
52 |> get("/api/v1/pleroma/chats/#{chat.id}/messages?max_id=#{List.last(result)["id"]}")
53 |> json_response_and_validate_schema(200)
55 assert length(result) == 10
58 test "it returns the messages for a given chat", %{conn: conn, user: user} do
59 other_user = insert(:user)
60 third_user = insert(:user)
62 {:ok, _} = CommonAPI.post_chat_message(user, other_user, "hey")
63 {:ok, _} = CommonAPI.post_chat_message(user, third_user, "hey")
64 {:ok, _} = CommonAPI.post_chat_message(user, other_user, "how are you?")
65 {:ok, _} = CommonAPI.post_chat_message(other_user, user, "fine, how about you?")
67 chat = Chat.get(user.id, other_user.ap_id)
71 |> get("/api/v1/pleroma/chats/#{chat.id}/messages")
72 |> json_response_and_validate_schema(200)
75 |> Enum.each(fn message ->
76 assert message["chat_id"] == chat.id |> to_string()
79 assert length(result) == 3
81 # Trying to get the chat of a different user
84 |> assign(:user, other_user)
85 |> get("/api/v1/pleroma/chats/#{chat.id}/messages")
87 assert result |> json_response(404)
91 describe "POST /api/v1/pleroma/chats/by-account-id/:id" do
92 setup do: oauth_access(["write:statuses"])
94 test "it creates or returns a chat", %{conn: conn} do
95 other_user = insert(:user)
99 |> post("/api/v1/pleroma/chats/by-account-id/#{other_user.id}")
100 |> json_response_and_validate_schema(200)
106 describe "GET /api/v1/pleroma/chats" do
107 setup do: oauth_access(["read:statuses"])
109 test "it paginates", %{conn: conn, user: user} do
110 Enum.each(1..30, fn _ ->
111 recipient = insert(:user)
112 {:ok, _} = Chat.get_or_create(user.id, recipient.ap_id)
117 |> get("/api/v1/pleroma/chats")
118 |> json_response_and_validate_schema(200)
120 assert length(result) == 20
124 |> get("/api/v1/pleroma/chats?max_id=#{List.last(result)["id"]}")
125 |> json_response_and_validate_schema(200)
127 assert length(result) == 10
130 test "it return a list of chats the current user is participating in, in descending order of updates",
131 %{conn: conn, user: user} do
133 jafnhar = insert(:user)
134 tridi = insert(:user)
136 {:ok, chat_1} = Chat.get_or_create(user.id, har.ap_id)
138 {:ok, _chat_2} = Chat.get_or_create(user.id, jafnhar.ap_id)
140 {:ok, chat_3} = Chat.get_or_create(user.id, tridi.ap_id)
143 # bump the second one
144 {:ok, chat_2} = Chat.bump_or_create(user.id, jafnhar.ap_id)
148 |> get("/api/v1/pleroma/chats")
149 |> json_response_and_validate_schema(200)
151 ids = Enum.map(result, & &1["id"])
154 chat_2.id |> to_string(),
155 chat_3.id |> to_string(),
156 chat_1.id |> to_string()