|
|
|
@ -28,7 +28,7 @@ defmodule Pleroma.Web.OStatusTest do
|
|
|
|
|
test "handle incoming note - GS, Salmon" do
|
|
|
|
|
incoming = File.read!("test/fixtures/incoming_note_activity.xml")
|
|
|
|
|
{:ok, [activity]} = OStatus.handle_incoming(incoming)
|
|
|
|
|
object = Object.normalize(activity.data["object"])
|
|
|
|
|
object = Object.normalize(activity)
|
|
|
|
|
|
|
|
|
|
user = User.get_cached_by_ap_id(activity.data["actor"])
|
|
|
|
|
assert user.info.note_count == 1
|
|
|
|
@ -51,7 +51,7 @@ defmodule Pleroma.Web.OStatusTest do
|
|
|
|
|
test "handle incoming notes - GS, subscription" do
|
|
|
|
|
incoming = File.read!("test/fixtures/ostatus_incoming_post.xml")
|
|
|
|
|
{:ok, [activity]} = OStatus.handle_incoming(incoming)
|
|
|
|
|
object = Object.normalize(activity.data["object"])
|
|
|
|
|
object = Object.normalize(activity)
|
|
|
|
|
|
|
|
|
|
assert activity.data["type"] == "Create"
|
|
|
|
|
assert object.data["type"] == "Note"
|
|
|
|
@ -65,7 +65,7 @@ defmodule Pleroma.Web.OStatusTest do
|
|
|
|
|
test "handle incoming notes with attachments - GS, subscription" do
|
|
|
|
|
incoming = File.read!("test/fixtures/incoming_websub_gnusocial_attachments.xml")
|
|
|
|
|
{:ok, [activity]} = OStatus.handle_incoming(incoming)
|
|
|
|
|
object = Object.normalize(activity.data["object"])
|
|
|
|
|
object = Object.normalize(activity)
|
|
|
|
|
|
|
|
|
|
assert activity.data["type"] == "Create"
|
|
|
|
|
assert object.data["type"] == "Note"
|
|
|
|
@ -78,7 +78,7 @@ defmodule Pleroma.Web.OStatusTest do
|
|
|
|
|
test "handle incoming notes with tags" do
|
|
|
|
|
incoming = File.read!("test/fixtures/ostatus_incoming_post_tag.xml")
|
|
|
|
|
{:ok, [activity]} = OStatus.handle_incoming(incoming)
|
|
|
|
|
object = Object.normalize(activity.data["object"])
|
|
|
|
|
object = Object.normalize(activity)
|
|
|
|
|
|
|
|
|
|
assert object.data["tag"] == ["nsfw"]
|
|
|
|
|
assert "https://www.w3.org/ns/activitystreams#Public" in activity.data["to"]
|
|
|
|
@ -95,7 +95,7 @@ defmodule Pleroma.Web.OStatusTest do
|
|
|
|
|
|
|
|
|
|
incoming = File.read!("test/fixtures/incoming_reply_mastodon.xml")
|
|
|
|
|
{:ok, [activity]} = OStatus.handle_incoming(incoming)
|
|
|
|
|
object = Object.normalize(activity.data["object"])
|
|
|
|
|
object = Object.normalize(activity)
|
|
|
|
|
|
|
|
|
|
assert activity.data["type"] == "Create"
|
|
|
|
|
assert object.data["type"] == "Note"
|
|
|
|
@ -107,7 +107,7 @@ defmodule Pleroma.Web.OStatusTest do
|
|
|
|
|
test "handle incoming notes - Mastodon, with CW" do
|
|
|
|
|
incoming = File.read!("test/fixtures/mastodon-note-cw.xml")
|
|
|
|
|
{:ok, [activity]} = OStatus.handle_incoming(incoming)
|
|
|
|
|
object = Object.normalize(activity.data["object"])
|
|
|
|
|
object = Object.normalize(activity)
|
|
|
|
|
|
|
|
|
|
assert activity.data["type"] == "Create"
|
|
|
|
|
assert object.data["type"] == "Note"
|
|
|
|
@ -119,7 +119,7 @@ defmodule Pleroma.Web.OStatusTest do
|
|
|
|
|
test "handle incoming unlisted messages, put public into cc" do
|
|
|
|
|
incoming = File.read!("test/fixtures/mastodon-note-unlisted.xml")
|
|
|
|
|
{:ok, [activity]} = OStatus.handle_incoming(incoming)
|
|
|
|
|
object = Object.normalize(activity.data["object"])
|
|
|
|
|
object = Object.normalize(activity)
|
|
|
|
|
|
|
|
|
|
refute "https://www.w3.org/ns/activitystreams#Public" in activity.data["to"]
|
|
|
|
|
assert "https://www.w3.org/ns/activitystreams#Public" in activity.data["cc"]
|
|
|
|
@ -130,7 +130,7 @@ defmodule Pleroma.Web.OStatusTest do
|
|
|
|
|
test "handle incoming retweets - Mastodon, with CW" do
|
|
|
|
|
incoming = File.read!("test/fixtures/cw_retweet.xml")
|
|
|
|
|
{:ok, [[_activity, retweeted_activity]]} = OStatus.handle_incoming(incoming)
|
|
|
|
|
retweeted_object = Object.normalize(retweeted_activity.data["object"])
|
|
|
|
|
retweeted_object = Object.normalize(retweeted_activity)
|
|
|
|
|
|
|
|
|
|
assert retweeted_object.data["summary"] == "Hey."
|
|
|
|
|
end
|
|
|
|
@ -138,7 +138,7 @@ defmodule Pleroma.Web.OStatusTest do
|
|
|
|
|
test "handle incoming notes - GS, subscription, reply" do
|
|
|
|
|
incoming = File.read!("test/fixtures/ostatus_incoming_reply.xml")
|
|
|
|
|
{:ok, [activity]} = OStatus.handle_incoming(incoming)
|
|
|
|
|
object = Object.normalize(activity.data["object"])
|
|
|
|
|
object = Object.normalize(activity)
|
|
|
|
|
|
|
|
|
|
assert activity.data["type"] == "Create"
|
|
|
|
|
assert object.data["type"] == "Note"
|
|
|
|
@ -164,7 +164,7 @@ defmodule Pleroma.Web.OStatusTest do
|
|
|
|
|
refute activity.local
|
|
|
|
|
|
|
|
|
|
retweeted_activity = Activity.get_by_id(retweeted_activity.id)
|
|
|
|
|
retweeted_object = Object.normalize(retweeted_activity.data["object"])
|
|
|
|
|
retweeted_object = Object.normalize(retweeted_activity)
|
|
|
|
|
assert retweeted_activity.data["type"] == "Create"
|
|
|
|
|
assert retweeted_activity.data["actor"] == "https://pleroma.soykaf.com/users/lain"
|
|
|
|
|
refute retweeted_activity.local
|
|
|
|
@ -176,18 +176,19 @@ defmodule Pleroma.Web.OStatusTest do
|
|
|
|
|
test "handle incoming retweets - GS, subscription - local message" do
|
|
|
|
|
incoming = File.read!("test/fixtures/share-gs-local.xml")
|
|
|
|
|
note_activity = insert(:note_activity)
|
|
|
|
|
object = Object.normalize(note_activity)
|
|
|
|
|
user = User.get_cached_by_ap_id(note_activity.data["actor"])
|
|
|
|
|
|
|
|
|
|
incoming =
|
|
|
|
|
incoming
|
|
|
|
|
|> String.replace("LOCAL_ID", note_activity.data["object"]["id"])
|
|
|
|
|
|> String.replace("LOCAL_ID", object.data["id"])
|
|
|
|
|
|> String.replace("LOCAL_USER", user.ap_id)
|
|
|
|
|
|
|
|
|
|
{:ok, [[activity, retweeted_activity]]} = OStatus.handle_incoming(incoming)
|
|
|
|
|
|
|
|
|
|
assert activity.data["type"] == "Announce"
|
|
|
|
|
assert activity.data["actor"] == "https://social.heldscal.la/user/23211"
|
|
|
|
|
assert activity.data["object"] == retweeted_activity.data["object"]["id"]
|
|
|
|
|
assert activity.data["object"] == object.data["id"]
|
|
|
|
|
assert user.ap_id in activity.data["to"]
|
|
|
|
|
refute activity.local
|
|
|
|
|
|
|
|
|
@ -202,7 +203,7 @@ defmodule Pleroma.Web.OStatusTest do
|
|
|
|
|
test "handle incoming retweets - Mastodon, salmon" do
|
|
|
|
|
incoming = File.read!("test/fixtures/share.xml")
|
|
|
|
|
{:ok, [[activity, retweeted_activity]]} = OStatus.handle_incoming(incoming)
|
|
|
|
|
retweeted_object = Object.normalize(retweeted_activity.data["object"])
|
|
|
|
|
retweeted_object = Object.normalize(retweeted_activity)
|
|
|
|
|
|
|
|
|
|
assert activity.data["type"] == "Announce"
|
|
|
|
|
assert activity.data["actor"] == "https://mastodon.social/users/lambadalambda"
|
|
|
|
@ -251,16 +252,17 @@ defmodule Pleroma.Web.OStatusTest do
|
|
|
|
|
|
|
|
|
|
test "handle incoming favorites with locally available object - GS, websub" do
|
|
|
|
|
note_activity = insert(:note_activity)
|
|
|
|
|
object = Object.normalize(note_activity)
|
|
|
|
|
|
|
|
|
|
incoming =
|
|
|
|
|
File.read!("test/fixtures/favorite_with_local_note.xml")
|
|
|
|
|
|> String.replace("localid", note_activity.data["object"]["id"])
|
|
|
|
|
|> String.replace("localid", object.data["id"])
|
|
|
|
|
|
|
|
|
|
{:ok, [[activity, favorited_activity]]} = OStatus.handle_incoming(incoming)
|
|
|
|
|
|
|
|
|
|
assert activity.data["type"] == "Like"
|
|
|
|
|
assert activity.data["actor"] == "https://social.heldscal.la/user/23211"
|
|
|
|
|
assert activity.data["object"] == favorited_activity.data["object"]["id"]
|
|
|
|
|
assert activity.data["object"] == object.data["id"]
|
|
|
|
|
refute activity.local
|
|
|
|
|
assert note_activity.id == favorited_activity.id
|
|
|
|
|
assert favorited_activity.local
|
|
|
|
@ -269,7 +271,7 @@ defmodule Pleroma.Web.OStatusTest do
|
|
|
|
|
test "handle incoming replies" do
|
|
|
|
|
incoming = File.read!("test/fixtures/incoming_note_activity_answer.xml")
|
|
|
|
|
{:ok, [activity]} = OStatus.handle_incoming(incoming)
|
|
|
|
|
object = Object.normalize(activity.data["object"])
|
|
|
|
|
object = Object.normalize(activity)
|
|
|
|
|
|
|
|
|
|
assert activity.data["type"] == "Create"
|
|
|
|
|
assert object.data["type"] == "Note"
|
|
|
|
@ -315,13 +317,14 @@ defmodule Pleroma.Web.OStatusTest do
|
|
|
|
|
"undo:tag:social.heldscal.la,2017-05-07:subscription:23211:person:44803:2017-05-07T09:54:48+00:00"
|
|
|
|
|
|
|
|
|
|
assert activity.data["actor"] == "https://social.heldscal.la/user/23211"
|
|
|
|
|
assert is_map(activity.data["object"])
|
|
|
|
|
assert activity.data["object"]["type"] == "Follow"
|
|
|
|
|
assert activity.data["object"]["object"] == "https://pawoo.net/users/pekorino"
|
|
|
|
|
embedded_object = activity.data["object"]
|
|
|
|
|
assert is_map(embedded_object)
|
|
|
|
|
assert embedded_object["type"] == "Follow"
|
|
|
|
|
assert embedded_object["object"] == "https://pawoo.net/users/pekorino"
|
|
|
|
|
refute activity.local
|
|
|
|
|
|
|
|
|
|
follower = User.get_cached_by_ap_id(activity.data["actor"])
|
|
|
|
|
followed = User.get_cached_by_ap_id(activity.data["object"]["object"])
|
|
|
|
|
followed = User.get_cached_by_ap_id(embedded_object["object"])
|
|
|
|
|
|
|
|
|
|
refute User.following?(follower, followed)
|
|
|
|
|
end
|
|
|
|
@ -538,8 +541,7 @@ defmodule Pleroma.Web.OStatusTest do
|
|
|
|
|
|
|
|
|
|
test "Article objects are not representable" do
|
|
|
|
|
note_activity = insert(:note_activity)
|
|
|
|
|
|
|
|
|
|
note_object = Object.normalize(note_activity.data["object"])
|
|
|
|
|
note_object = Object.normalize(note_activity)
|
|
|
|
|
|
|
|
|
|
note_data =
|
|
|
|
|
note_object.data
|
|
|
|
|