forked from AkkomaGang/akkoma
Merge branch 'sideeffects-test' into 'develop'
SideEffects: Test for notification creation. See merge request pleroma/pleroma!2399
This commit is contained in:
commit
e0d7847bc5
2 changed files with 12 additions and 2 deletions
|
@ -17,7 +17,9 @@ def handle(object, meta \\ [])
|
||||||
def handle(%{data: %{"type" => "Like"}} = object, meta) do
|
def handle(%{data: %{"type" => "Like"}} = object, meta) do
|
||||||
liked_object = Object.get_by_ap_id(object.data["object"])
|
liked_object = Object.get_by_ap_id(object.data["object"])
|
||||||
Utils.add_like_to_object(object, liked_object)
|
Utils.add_like_to_object(object, liked_object)
|
||||||
|
|
||||||
Notification.create_notifications(object)
|
Notification.create_notifications(object)
|
||||||
|
|
||||||
{:ok, object, meta}
|
{:ok, object, meta}
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -5,7 +5,9 @@
|
||||||
defmodule Pleroma.Web.ActivityPub.SideEffectsTest do
|
defmodule Pleroma.Web.ActivityPub.SideEffectsTest do
|
||||||
use Pleroma.DataCase
|
use Pleroma.DataCase
|
||||||
|
|
||||||
|
alias Pleroma.Notification
|
||||||
alias Pleroma.Object
|
alias Pleroma.Object
|
||||||
|
alias Pleroma.Repo
|
||||||
alias Pleroma.Web.ActivityPub.ActivityPub
|
alias Pleroma.Web.ActivityPub.ActivityPub
|
||||||
alias Pleroma.Web.ActivityPub.Builder
|
alias Pleroma.Web.ActivityPub.Builder
|
||||||
alias Pleroma.Web.ActivityPub.SideEffects
|
alias Pleroma.Web.ActivityPub.SideEffects
|
||||||
|
@ -15,13 +17,14 @@ defmodule Pleroma.Web.ActivityPub.SideEffectsTest do
|
||||||
|
|
||||||
describe "like objects" do
|
describe "like objects" do
|
||||||
setup do
|
setup do
|
||||||
|
poster = insert(:user)
|
||||||
user = insert(:user)
|
user = insert(:user)
|
||||||
{:ok, post} = CommonAPI.post(user, %{"status" => "hey"})
|
{:ok, post} = CommonAPI.post(poster, %{"status" => "hey"})
|
||||||
|
|
||||||
{:ok, like_data, _meta} = Builder.like(user, post.object)
|
{:ok, like_data, _meta} = Builder.like(user, post.object)
|
||||||
{:ok, like, _meta} = ActivityPub.persist(like_data, local: true)
|
{:ok, like, _meta} = ActivityPub.persist(like_data, local: true)
|
||||||
|
|
||||||
%{like: like, user: user}
|
%{like: like, user: user, poster: poster}
|
||||||
end
|
end
|
||||||
|
|
||||||
test "add the like to the original object", %{like: like, user: user} do
|
test "add the like to the original object", %{like: like, user: user} do
|
||||||
|
@ -30,5 +33,10 @@ test "add the like to the original object", %{like: like, user: user} do
|
||||||
assert object.data["like_count"] == 1
|
assert object.data["like_count"] == 1
|
||||||
assert user.ap_id in object.data["likes"]
|
assert user.ap_id in object.data["likes"]
|
||||||
end
|
end
|
||||||
|
|
||||||
|
test "creates a notification", %{like: like, poster: poster} do
|
||||||
|
{:ok, like, _} = SideEffects.handle(like)
|
||||||
|
assert Repo.get_by(Notification, user_id: poster.id, activity_id: like.id)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue