2019-07-10 07:13:23 +02:00
|
|
|
# Pleroma: A lightweight social networking server
|
2020-03-02 06:08:45 +01:00
|
|
|
# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>
|
2019-07-10 07:13:23 +02:00
|
|
|
# SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
|
2017-12-11 18:19:46 +01:00
|
|
|
defmodule Pleroma.Web.ActivityPub.ObjectViewTest do
|
|
|
|
use Pleroma.DataCase
|
|
|
|
import Pleroma.Factory
|
|
|
|
|
2019-07-08 18:53:02 +02:00
|
|
|
alias Pleroma.Object
|
2017-12-11 18:19:46 +01:00
|
|
|
alias Pleroma.Web.ActivityPub.ObjectView
|
2019-03-05 03:52:23 +01:00
|
|
|
alias Pleroma.Web.CommonAPI
|
2017-12-11 18:19:46 +01:00
|
|
|
|
|
|
|
test "renders a note object" do
|
|
|
|
note = insert(:note)
|
|
|
|
|
|
|
|
result = ObjectView.render("object.json", %{object: note})
|
|
|
|
|
|
|
|
assert result["id"] == note.data["id"]
|
|
|
|
assert result["to"] == note.data["to"]
|
|
|
|
assert result["content"] == note.data["content"]
|
|
|
|
assert result["type"] == "Note"
|
2018-11-08 16:05:28 +01:00
|
|
|
assert result["@context"]
|
2017-12-11 18:19:46 +01:00
|
|
|
end
|
2018-11-17 23:29:08 +01:00
|
|
|
|
|
|
|
test "renders a note activity" do
|
|
|
|
note = insert(:note_activity)
|
2019-07-09 21:37:59 +02:00
|
|
|
object = Object.normalize(note)
|
2018-11-17 23:29:08 +01:00
|
|
|
|
|
|
|
result = ObjectView.render("object.json", %{object: note})
|
|
|
|
|
|
|
|
assert result["id"] == note.data["id"]
|
|
|
|
assert result["to"] == note.data["to"]
|
|
|
|
assert result["object"]["type"] == "Note"
|
2019-07-08 18:53:02 +02:00
|
|
|
assert result["object"]["content"] == object.data["content"]
|
2018-11-17 23:29:08 +01:00
|
|
|
assert result["type"] == "Create"
|
|
|
|
assert result["@context"]
|
|
|
|
end
|
|
|
|
|
2020-02-08 17:58:02 +01:00
|
|
|
describe "note activity's `replies` collection rendering" do
|
|
|
|
clear_config([:activitypub, :note_replies_output_limit]) do
|
|
|
|
Pleroma.Config.put([:activitypub, :note_replies_output_limit], 5)
|
|
|
|
end
|
|
|
|
|
|
|
|
test "renders `replies` collection for a note activity" do
|
|
|
|
user = insert(:user)
|
|
|
|
activity = insert(:note_activity, user: user)
|
|
|
|
|
|
|
|
{:ok, self_reply1} =
|
|
|
|
CommonAPI.post(user, %{"status" => "self-reply 1", "in_reply_to_status_id" => activity.id})
|
|
|
|
|
2020-02-09 08:17:21 +01:00
|
|
|
replies_uris = [self_reply1.object.data["id"]]
|
2020-02-08 17:58:02 +01:00
|
|
|
result = ObjectView.render("object.json", %{object: refresh_record(activity)})
|
|
|
|
|
2020-02-09 15:34:48 +01:00
|
|
|
assert %{"type" => "Collection", "items" => ^replies_uris} =
|
|
|
|
get_in(result, ["object", "replies"])
|
2020-02-08 17:58:02 +01:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-11-17 23:29:08 +01:00
|
|
|
test "renders a like activity" do
|
|
|
|
note = insert(:note_activity)
|
2019-07-08 18:53:02 +02:00
|
|
|
object = Object.normalize(note)
|
2018-11-17 23:29:08 +01:00
|
|
|
user = insert(:user)
|
|
|
|
|
|
|
|
{:ok, like_activity, _} = CommonAPI.favorite(note.id, user)
|
|
|
|
|
|
|
|
result = ObjectView.render("object.json", %{object: like_activity})
|
|
|
|
|
|
|
|
assert result["id"] == like_activity.data["id"]
|
2019-07-08 18:53:02 +02:00
|
|
|
assert result["object"] == object.data["id"]
|
2018-11-17 23:29:08 +01:00
|
|
|
assert result["type"] == "Like"
|
|
|
|
end
|
|
|
|
|
|
|
|
test "renders an announce activity" do
|
|
|
|
note = insert(:note_activity)
|
2019-07-08 18:53:02 +02:00
|
|
|
object = Object.normalize(note)
|
2018-11-17 23:29:08 +01:00
|
|
|
user = insert(:user)
|
|
|
|
|
|
|
|
{:ok, announce_activity, _} = CommonAPI.repeat(note.id, user)
|
|
|
|
|
|
|
|
result = ObjectView.render("object.json", %{object: announce_activity})
|
|
|
|
|
|
|
|
assert result["id"] == announce_activity.data["id"]
|
2019-07-08 18:53:02 +02:00
|
|
|
assert result["object"] == object.data["id"]
|
2018-11-17 23:29:08 +01:00
|
|
|
assert result["type"] == "Announce"
|
|
|
|
end
|
2017-12-11 18:19:46 +01:00
|
|
|
end
|