logo

pleroma

My custom branche(s) on git.pleroma.social/pleroma/pleroma git clone https://hacktivis.me/git/pleroma.git

activity_test.exs (10371B)


  1. # Pleroma: A lightweight social networking server
  2. # Copyright © 2017-2022 Pleroma Authors <https://pleroma.social/>
  3. # SPDX-License-Identifier: AGPL-3.0-only
  4. defmodule Pleroma.ActivityTest do
  5. use Pleroma.DataCase
  6. alias Pleroma.Activity
  7. alias Pleroma.Bookmark
  8. alias Pleroma.Object
  9. alias Pleroma.Tests.ObanHelpers
  10. alias Pleroma.ThreadMute
  11. import Pleroma.Factory
  12. setup_all do
  13. Tesla.Mock.mock_global(fn env -> apply(HttpRequestMock, :request, [env]) end)
  14. :ok
  15. end
  16. test "returns an activity by it's AP id" do
  17. activity = insert(:note_activity)
  18. found_activity = Activity.get_by_ap_id(activity.data["id"])
  19. assert activity == found_activity
  20. end
  21. test "returns activities by it's objects AP ids" do
  22. activity = insert(:note_activity)
  23. object_data = Object.normalize(activity, fetch: false).data
  24. [found_activity] = Activity.get_all_create_by_object_ap_id(object_data["id"])
  25. assert activity == found_activity
  26. end
  27. test "returns the activity that created an object" do
  28. activity = insert(:note_activity)
  29. object_data = Object.normalize(activity, fetch: false).data
  30. found_activity = Activity.get_create_by_object_ap_id(object_data["id"])
  31. assert activity == found_activity
  32. end
  33. test "preloading a bookmark" do
  34. user = insert(:user)
  35. user2 = insert(:user)
  36. user3 = insert(:user)
  37. activity = insert(:note_activity)
  38. {:ok, _bookmark} = Bookmark.create(user.id, activity.id)
  39. {:ok, _bookmark2} = Bookmark.create(user2.id, activity.id)
  40. {:ok, bookmark3} = Bookmark.create(user3.id, activity.id)
  41. queried_activity =
  42. Ecto.Query.from(Pleroma.Activity)
  43. |> Activity.with_preloaded_bookmark(user3)
  44. |> Repo.one()
  45. assert queried_activity.bookmark == bookmark3
  46. end
  47. test "setting thread_muted?" do
  48. activity = insert(:note_activity)
  49. user = insert(:user)
  50. annoyed_user = insert(:user)
  51. {:ok, _} = ThreadMute.add_mute(annoyed_user.id, activity.data["context"])
  52. activity_with_unset_thread_muted_field =
  53. Ecto.Query.from(Activity)
  54. |> Repo.one()
  55. activity_for_user =
  56. Ecto.Query.from(Activity)
  57. |> Activity.with_set_thread_muted_field(user)
  58. |> Repo.one()
  59. activity_for_annoyed_user =
  60. Ecto.Query.from(Activity)
  61. |> Activity.with_set_thread_muted_field(annoyed_user)
  62. |> Repo.one()
  63. assert activity_with_unset_thread_muted_field.thread_muted? == nil
  64. assert activity_for_user.thread_muted? == false
  65. assert activity_for_annoyed_user.thread_muted? == true
  66. end
  67. describe "getting a bookmark" do
  68. test "when association is loaded" do
  69. user = insert(:user)
  70. activity = insert(:note_activity)
  71. {:ok, bookmark} = Bookmark.create(user.id, activity.id)
  72. queried_activity =
  73. Ecto.Query.from(Pleroma.Activity)
  74. |> Activity.with_preloaded_bookmark(user)
  75. |> Repo.one()
  76. assert Activity.get_bookmark(queried_activity, user) == bookmark
  77. end
  78. test "when association is not loaded" do
  79. user = insert(:user)
  80. activity = insert(:note_activity)
  81. {:ok, bookmark} = Bookmark.create(user.id, activity.id)
  82. queried_activity =
  83. Ecto.Query.from(Pleroma.Activity)
  84. |> Repo.one()
  85. assert Activity.get_bookmark(queried_activity, user) == bookmark
  86. end
  87. end
  88. describe "search" do
  89. setup do
  90. user = insert(:user)
  91. params = %{
  92. "@context" => "https://www.w3.org/ns/activitystreams",
  93. "actor" => "http://mastodon.example.org/users/admin",
  94. "type" => "Create",
  95. "id" => "http://mastodon.example.org/users/admin/activities/1",
  96. "object" => %{
  97. "type" => "Note",
  98. "content" => "find me!",
  99. "id" => "http://mastodon.example.org/users/admin/objects/1",
  100. "attributedTo" => "http://mastodon.example.org/users/admin",
  101. "to" => ["https://www.w3.org/ns/activitystreams#Public"]
  102. },
  103. "to" => ["https://www.w3.org/ns/activitystreams#Public"]
  104. }
  105. {:ok, local_activity} = Pleroma.Web.CommonAPI.post(user, %{status: "find me!"})
  106. {:ok, japanese_activity} = Pleroma.Web.CommonAPI.post(user, %{status: "更新情報"})
  107. {:ok, job} = Pleroma.Web.Federator.incoming_ap_doc(params)
  108. {:ok, remote_activity} = ObanHelpers.perform(job)
  109. remote_activity = Activity.get_by_id_with_object(remote_activity.id)
  110. %{
  111. japanese_activity: japanese_activity,
  112. local_activity: local_activity,
  113. remote_activity: remote_activity,
  114. user: user
  115. }
  116. end
  117. setup do: clear_config([:instance, :limit_to_local_content])
  118. @tag :skip_darwin
  119. test "finds utf8 text in statuses", %{
  120. japanese_activity: japanese_activity,
  121. user: user
  122. } do
  123. activities = Activity.search(user, "更新情報")
  124. assert [^japanese_activity] = activities
  125. end
  126. test "find local and remote statuses for authenticated users", %{
  127. local_activity: local_activity,
  128. remote_activity: remote_activity,
  129. user: user
  130. } do
  131. activities = Enum.sort_by(Activity.search(user, "find me"), & &1.id)
  132. assert [^local_activity, ^remote_activity] = activities
  133. end
  134. test "find only local statuses for unauthenticated users", %{local_activity: local_activity} do
  135. assert [^local_activity] = Activity.search(nil, "find me")
  136. end
  137. test "find only local statuses for unauthenticated users when `limit_to_local_content` is `:all`",
  138. %{local_activity: local_activity} do
  139. clear_config([:instance, :limit_to_local_content], :all)
  140. assert [^local_activity] = Activity.search(nil, "find me")
  141. end
  142. test "find all statuses for unauthenticated users when `limit_to_local_content` is `false`",
  143. %{
  144. local_activity: local_activity,
  145. remote_activity: remote_activity
  146. } do
  147. clear_config([:instance, :limit_to_local_content], false)
  148. activities = Enum.sort_by(Activity.search(nil, "find me"), & &1.id)
  149. assert [^local_activity, ^remote_activity] = activities
  150. end
  151. end
  152. test "all_by_ids_with_object/1" do
  153. %{id: id1} = insert(:note_activity)
  154. %{id: id2} = insert(:note_activity)
  155. activities =
  156. [id1, id2]
  157. |> Activity.all_by_ids_with_object()
  158. |> Enum.sort(&(&1.id < &2.id))
  159. assert [%{id: ^id1, object: %Object{}}, %{id: ^id2, object: %Object{}}] = activities
  160. end
  161. test "get_by_id_with_user_actor/1" do
  162. user = insert(:user)
  163. activity = insert(:note_activity, note: insert(:note, user: user))
  164. assert Activity.get_by_id_with_user_actor(activity.id).user_actor == user
  165. end
  166. test "get_by_id_with_object/1" do
  167. %{id: id} = insert(:note_activity)
  168. assert %Activity{id: ^id, object: %Object{}} = Activity.get_by_id_with_object(id)
  169. end
  170. test "get_by_ap_id_with_object/1" do
  171. %{data: %{"id" => ap_id}} = insert(:note_activity)
  172. assert %Activity{data: %{"id" => ^ap_id}, object: %Object{}} =
  173. Activity.get_by_ap_id_with_object(ap_id)
  174. end
  175. test "get_by_id/1" do
  176. %{id: id} = insert(:note_activity)
  177. assert %Activity{id: ^id} = Activity.get_by_id(id)
  178. end
  179. test "all_by_actor_and_id/2" do
  180. user = insert(:user)
  181. {:ok, %{id: id1}} = Pleroma.Web.CommonAPI.post(user, %{status: "cofe"})
  182. {:ok, %{id: id2}} = Pleroma.Web.CommonAPI.post(user, %{status: "cofefe"})
  183. assert [] == Activity.all_by_actor_and_id(user, [])
  184. activities =
  185. user.ap_id
  186. |> Activity.all_by_actor_and_id([id1, id2])
  187. |> Enum.sort(&(&1.id < &2.id))
  188. assert [%Activity{id: ^id1}, %Activity{id: ^id2}] = activities
  189. end
  190. test "get_by_object_ap_id_with_object/1" do
  191. user = insert(:user)
  192. another = insert(:user)
  193. {:ok, %{id: id, object: %{data: %{"id" => obj_id}}}} =
  194. Pleroma.Web.CommonAPI.post(user, %{status: "cofe"})
  195. Pleroma.Web.CommonAPI.favorite(another, id)
  196. assert obj_id
  197. |> Pleroma.Activity.Queries.by_object_id()
  198. |> Repo.aggregate(:count, :id) == 2
  199. assert %{id: ^id} = Activity.get_by_object_ap_id_with_object(obj_id)
  200. end
  201. test "add_by_params_query/3" do
  202. user = insert(:user)
  203. note = insert(:note_activity, user: user)
  204. insert(:add_activity, user: user, note: note)
  205. insert(:add_activity, user: user, note: note)
  206. insert(:add_activity, user: user)
  207. assert Repo.aggregate(Activity, :count, :id) == 4
  208. add_query =
  209. Activity.add_by_params_query(note.data["object"], user.ap_id, user.featured_address)
  210. assert Repo.aggregate(add_query, :count, :id) == 2
  211. Repo.delete_all(add_query)
  212. assert Repo.aggregate(add_query, :count, :id) == 0
  213. assert Repo.aggregate(Activity, :count, :id) == 2
  214. end
  215. describe "associated_object_id() sql function" do
  216. test "with json object" do
  217. %{rows: [[object_id]]} =
  218. Ecto.Adapters.SQL.query!(
  219. Pleroma.Repo,
  220. """
  221. select associated_object_id('{"object": {"id":"foobar"}}'::jsonb);
  222. """
  223. )
  224. assert object_id == "foobar"
  225. end
  226. test "with string object" do
  227. %{rows: [[object_id]]} =
  228. Ecto.Adapters.SQL.query!(
  229. Pleroma.Repo,
  230. """
  231. select associated_object_id('{"object": "foobar"}'::jsonb);
  232. """
  233. )
  234. assert object_id == "foobar"
  235. end
  236. test "with array object" do
  237. %{rows: [[object_id]]} =
  238. Ecto.Adapters.SQL.query!(
  239. Pleroma.Repo,
  240. """
  241. select associated_object_id('{"object": ["foobar", {}]}'::jsonb);
  242. """
  243. )
  244. assert object_id == "foobar"
  245. end
  246. test "invalid" do
  247. %{rows: [[object_id]]} =
  248. Ecto.Adapters.SQL.query!(
  249. Pleroma.Repo,
  250. """
  251. select associated_object_id('{"object": {}}'::jsonb);
  252. """
  253. )
  254. assert is_nil(object_id)
  255. end
  256. test "invalid object id" do
  257. %{rows: [[object_id]]} =
  258. Ecto.Adapters.SQL.query!(
  259. Pleroma.Repo,
  260. """
  261. select associated_object_id('{"object": {"id": 123}}'::jsonb);
  262. """
  263. )
  264. assert is_nil(object_id)
  265. end
  266. test "no object field" do
  267. %{rows: [[object_id]]} =
  268. Ecto.Adapters.SQL.query!(
  269. Pleroma.Repo,
  270. """
  271. select associated_object_id('{}'::jsonb);
  272. """
  273. )
  274. assert is_nil(object_id)
  275. end
  276. end
  277. end