aboutsummaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorrinpatch <rinpatch@sdf.org>2019-05-04 12:46:42 +0300
committerWilliam Pitcock <nenolod@dereferenced.org>2019-05-07 19:33:22 +0000
commitf841eb7cdb83afc444dfe260581b6be6e690a717 (patch)
tree63146e5aa7e818f7c7ab621dbeaecf6d945ef631 /test
parent06947c91471fda6e774c5b6fc04720b87db2b1e6 (diff)
downloadpleroma-f841eb7cdb83afc444dfe260581b6be6e690a717.tar.gz
Preload bookmarks wherever the object is preloaded
Diffstat (limited to 'test')
-rw-r--r--test/activity_test.exs29
1 files changed, 29 insertions, 0 deletions
diff --git a/test/activity_test.exs b/test/activity_test.exs
index ad889f544..e2a8baada 100644
--- a/test/activity_test.exs
+++ b/test/activity_test.exs
@@ -5,6 +5,8 @@
defmodule Pleroma.ActivityTest do
use Pleroma.DataCase
alias Pleroma.Activity
+ alias Pleroma.Bookmark
+ alias Pleroma.Object
import Pleroma.Factory
test "returns an activity by it's AP id" do
@@ -28,4 +30,31 @@ defmodule Pleroma.ActivityTest do
assert activity == found_activity
end
+
+ test "preloading object preloads bookmarks" do
+ user1 = insert(:user)
+ user2 = insert(:user)
+ activity = insert(:note_activity)
+ {:ok, bookmark1} = Bookmark.create(user1.id, activity.id)
+ {:ok, bookmark2} = Bookmark.create(user2.id, activity.id)
+ bookmarks = Enum.sort([bookmark1, bookmark2])
+
+ queried_activity =
+ Ecto.Query.from(a in Activity, where: a.id == ^activity.id)
+ |> Activity.with_preloaded_object()
+ |> Repo.one()
+
+ assert Enum.sort(queried_activity.bookmarks) == bookmarks
+
+ queried_activity = Activity.get_by_ap_id_with_object(activity.data["id"])
+ assert Enum.sort(queried_activity.bookmarks) == bookmarks
+
+ queried_activity = Activity.get_by_id_with_object(activity.id)
+ assert Enum.sort(queried_activity.bookmarks) == bookmarks
+
+ queried_activity =
+ Activity.get_create_by_object_ap_id_with_object(Object.normalize(activity).data["id"])
+
+ assert Enum.sort(queried_activity.bookmarks) == bookmarks
+ end
end