1 # Pleroma: A lightweight social networking server
2 # Copyright © 2017-2022 Pleroma Authors <https://pleroma.social/>
3 # SPDX-License-Identifier: AGPL-3.0-only
5 defmodule Pleroma.ActivityTest do
10 alias Pleroma.Tests.ObanHelpers
11 alias Pleroma.ThreadMute
12 import Pleroma.Factory
15 Tesla.Mock.mock_global(fn env -> apply(HttpRequestMock, :request, [env]) end)
19 test "returns an activity by it's AP id" do
20 activity = insert(:note_activity)
21 found_activity = Activity.get_by_ap_id(activity.data["id"])
23 assert activity == found_activity
26 test "returns activities by it's objects AP ids" do
27 activity = insert(:note_activity)
28 object_data = Object.normalize(activity, fetch: false).data
30 [found_activity] = Activity.get_all_create_by_object_ap_id(object_data["id"])
32 assert activity == found_activity
35 test "returns the activity that created an object" do
36 activity = insert(:note_activity)
37 object_data = Object.normalize(activity, fetch: false).data
39 found_activity = Activity.get_create_by_object_ap_id(object_data["id"])
41 assert activity == found_activity
44 test "preloading a bookmark" do
48 activity = insert(:note_activity)
49 {:ok, _bookmark} = Bookmark.create(user.id, activity.id)
50 {:ok, _bookmark2} = Bookmark.create(user2.id, activity.id)
51 {:ok, bookmark3} = Bookmark.create(user3.id, activity.id)
54 Ecto.Query.from(Pleroma.Activity)
55 |> Activity.with_preloaded_bookmark(user3)
58 assert queried_activity.bookmark == bookmark3
61 test "setting thread_muted?" do
62 activity = insert(:note_activity)
64 annoyed_user = insert(:user)
65 {:ok, _} = ThreadMute.add_mute(annoyed_user.id, activity.data["context"])
67 activity_with_unset_thread_muted_field =
68 Ecto.Query.from(Activity)
72 Ecto.Query.from(Activity)
73 |> Activity.with_set_thread_muted_field(user)
76 activity_for_annoyed_user =
77 Ecto.Query.from(Activity)
78 |> Activity.with_set_thread_muted_field(annoyed_user)
81 assert activity_with_unset_thread_muted_field.thread_muted? == nil
82 assert activity_for_user.thread_muted? == false
83 assert activity_for_annoyed_user.thread_muted? == true
86 describe "getting a bookmark" do
87 test "when association is loaded" do
89 activity = insert(:note_activity)
90 {:ok, bookmark} = Bookmark.create(user.id, activity.id)
93 Ecto.Query.from(Pleroma.Activity)
94 |> Activity.with_preloaded_bookmark(user)
97 assert Activity.get_bookmark(queried_activity, user) == bookmark
100 test "when association is not loaded" do
102 activity = insert(:note_activity)
103 {:ok, bookmark} = Bookmark.create(user.id, activity.id)
106 Ecto.Query.from(Pleroma.Activity)
109 assert Activity.get_bookmark(queried_activity, user) == bookmark
118 "@context" => "https://www.w3.org/ns/activitystreams",
119 "actor" => "http://mastodon.example.org/users/admin",
121 "id" => "http://mastodon.example.org/users/admin/activities/1",
124 "content" => "find me!",
125 "id" => "http://mastodon.example.org/users/admin/objects/1",
126 "attributedTo" => "http://mastodon.example.org/users/admin",
127 "to" => ["https://www.w3.org/ns/activitystreams#Public"]
129 "to" => ["https://www.w3.org/ns/activitystreams#Public"]
132 {:ok, local_activity} = Pleroma.Web.CommonAPI.post(user, %{status: "find me!"})
133 {:ok, japanese_activity} = Pleroma.Web.CommonAPI.post(user, %{status: "更新情報"})
134 {:ok, job} = Pleroma.Web.Federator.incoming_ap_doc(params)
135 {:ok, remote_activity} = ObanHelpers.perform(job)
136 remote_activity = Activity.get_by_id_with_object(remote_activity.id)
139 japanese_activity: japanese_activity,
140 local_activity: local_activity,
141 remote_activity: remote_activity,
146 setup do: clear_config([:instance, :limit_to_local_content])
149 test "finds utf8 text in statuses", %{
150 japanese_activity: japanese_activity,
153 activities = Activity.search(user, "更新情報")
155 assert [^japanese_activity] = activities
158 test "find local and remote statuses for authenticated users", %{
159 local_activity: local_activity,
160 remote_activity: remote_activity,
163 activities = Enum.sort_by(Activity.search(user, "find me"), & &1.id)
165 assert [^local_activity, ^remote_activity] = activities
168 test "find only local statuses for unauthenticated users", %{local_activity: local_activity} do
169 assert [^local_activity] = Activity.search(nil, "find me")
172 test "find only local statuses for unauthenticated users when `limit_to_local_content` is `:all`",
173 %{local_activity: local_activity} do
174 clear_config([:instance, :limit_to_local_content], :all)
175 assert [^local_activity] = Activity.search(nil, "find me")
178 test "find all statuses for unauthenticated users when `limit_to_local_content` is `false`",
180 local_activity: local_activity,
181 remote_activity: remote_activity
183 clear_config([:instance, :limit_to_local_content], false)
185 activities = Enum.sort_by(Activity.search(nil, "find me"), & &1.id)
187 assert [^local_activity, ^remote_activity] = activities
191 test "all_by_ids_with_object/1" do
192 %{id: id1} = insert(:note_activity)
193 %{id: id2} = insert(:note_activity)
197 |> Activity.all_by_ids_with_object()
198 |> Enum.sort(&(&1.id < &2.id))
200 assert [%{id: ^id1, object: %Object{}}, %{id: ^id2, object: %Object{}}] = activities
203 test "get_by_id_with_user_actor/1" do
205 activity = insert(:note_activity, note: insert(:note, user: user))
207 assert Activity.get_by_id_with_user_actor(activity.id).user_actor == user
210 test "get_by_id_with_object/1" do
211 %{id: id} = insert(:note_activity)
213 assert %Activity{id: ^id, object: %Object{}} = Activity.get_by_id_with_object(id)
216 test "get_by_ap_id_with_object/1" do
217 %{data: %{"id" => ap_id}} = insert(:note_activity)
219 assert %Activity{data: %{"id" => ^ap_id}, object: %Object{}} =
220 Activity.get_by_ap_id_with_object(ap_id)
223 test "get_by_id/1" do
224 %{id: id} = insert(:note_activity)
226 assert %Activity{id: ^id} = Activity.get_by_id(id)
229 test "all_by_actor_and_id/2" do
232 {:ok, %{id: id1}} = Pleroma.Web.CommonAPI.post(user, %{status: "cofe"})
233 {:ok, %{id: id2}} = Pleroma.Web.CommonAPI.post(user, %{status: "cofefe"})
235 assert [] == Activity.all_by_actor_and_id(user, [])
239 |> Activity.all_by_actor_and_id([id1, id2])
240 |> Enum.sort(&(&1.id < &2.id))
242 assert [%Activity{id: ^id1}, %Activity{id: ^id2}] = activities
245 test "get_by_object_ap_id_with_object/1" do
247 another = insert(:user)
249 {:ok, %{id: id, object: %{data: %{"id" => obj_id}}}} =
250 Pleroma.Web.CommonAPI.post(user, %{status: "cofe"})
252 Pleroma.Web.CommonAPI.favorite(another, id)
255 |> Pleroma.Activity.Queries.by_object_id()
256 |> Repo.aggregate(:count, :id) == 2
258 assert %{id: ^id} = Activity.get_by_object_ap_id_with_object(obj_id)
261 test "add_by_params_query/3" do
264 note = insert(:note_activity, user: user)
266 insert(:add_activity, user: user, note: note)
267 insert(:add_activity, user: user, note: note)
268 insert(:add_activity, user: user)
270 assert Repo.aggregate(Activity, :count, :id) == 4
273 Activity.add_by_params_query(note.data["object"], user.ap_id, user.featured_address)
275 assert Repo.aggregate(add_query, :count, :id) == 2
277 Repo.delete_all(add_query)
278 assert Repo.aggregate(add_query, :count, :id) == 0
280 assert Repo.aggregate(Activity, :count, :id) == 2
283 describe "associated_object_id() sql function" do
284 test "with json object" do
285 %{rows: [[object_id]]} =
286 Ecto.Adapters.SQL.query!(
289 select associated_object_id('{"object": {"id":"foobar"}}'::jsonb);
293 assert object_id == "foobar"
296 test "with string object" do
297 %{rows: [[object_id]]} =
298 Ecto.Adapters.SQL.query!(
301 select associated_object_id('{"object": "foobar"}'::jsonb);
305 assert object_id == "foobar"
308 test "with array object" do
309 %{rows: [[object_id]]} =
310 Ecto.Adapters.SQL.query!(
313 select associated_object_id('{"object": ["foobar", {}]}'::jsonb);
317 assert object_id == "foobar"
321 %{rows: [[object_id]]} =
322 Ecto.Adapters.SQL.query!(
325 select associated_object_id('{"object": {}}'::jsonb);
329 assert is_nil(object_id)
332 test "invalid object id" do
333 %{rows: [[object_id]]} =
334 Ecto.Adapters.SQL.query!(
337 select associated_object_id('{"object": {"id": 123}}'::jsonb);
341 assert is_nil(object_id)
344 test "no object field" do
345 %{rows: [[object_id]]} =
346 Ecto.Adapters.SQL.query!(
349 select associated_object_id('{}'::jsonb);
353 assert is_nil(object_id)