forked from AkkomaGang/akkoma
tests: fix most remaining failures
This commit is contained in:
parent
cf139e3eec
commit
4ca4c83871
4 changed files with 95 additions and 66 deletions
test/web
activity_pub
common_api
ostatus
|
@ -77,8 +77,10 @@ test "adds an id to a given object if it lacks one and is a note and inserts it
|
||||||
}
|
}
|
||||||
|
|
||||||
{:ok, %Activity{} = activity} = ActivityPub.insert(data)
|
{:ok, %Activity{} = activity} = ActivityPub.insert(data)
|
||||||
assert is_binary(activity.data["object"]["id"])
|
object = Object.normalize(activity.data["object"])
|
||||||
assert %Object{} = Object.get_by_ap_id(activity.data["object"]["id"])
|
|
||||||
|
assert is_binary(object.data["id"])
|
||||||
|
assert %Object{} = Object.get_by_ap_id(activity.data["object"])
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -4,7 +4,7 @@ defmodule Pleroma.Web.ActivityPub.TransmogrifierTest do
|
||||||
alias Pleroma.Web.ActivityPub.Utils
|
alias Pleroma.Web.ActivityPub.Utils
|
||||||
alias Pleroma.Web.ActivityPub.ActivityPub
|
alias Pleroma.Web.ActivityPub.ActivityPub
|
||||||
alias Pleroma.Web.OStatus
|
alias Pleroma.Web.OStatus
|
||||||
alias Pleroma.Activity
|
alias Pleroma.{Activity, Object}
|
||||||
alias Pleroma.User
|
alias Pleroma.User
|
||||||
alias Pleroma.Repo
|
alias Pleroma.Repo
|
||||||
alias Pleroma.Web.Websub.WebsubClientSubscription
|
alias Pleroma.Web.Websub.WebsubClientSubscription
|
||||||
|
@ -40,16 +40,16 @@ test "it fetches replied-to activities if we don't have them" do
|
||||||
|> Map.put("object", object)
|
|> Map.put("object", object)
|
||||||
|
|
||||||
{:ok, returned_activity} = Transmogrifier.handle_incoming(data)
|
{:ok, returned_activity} = Transmogrifier.handle_incoming(data)
|
||||||
|
returned_object = Object.normalize(returned_activity.data["object"])
|
||||||
|
|
||||||
assert activity =
|
assert activity =
|
||||||
Activity.get_create_activity_by_object_ap_id(
|
Activity.get_create_activity_by_object_ap_id(
|
||||||
"tag:shitposter.club,2017-05-05:noticeId=2827873:objectType=comment"
|
"tag:shitposter.club,2017-05-05:noticeId=2827873:objectType=comment"
|
||||||
)
|
)
|
||||||
|
|
||||||
assert returned_activity.data["object"]["inReplyToAtomUri"] ==
|
assert returned_object.data["inReplyToAtomUri"] == "https://shitposter.club/notice/2827873"
|
||||||
"https://shitposter.club/notice/2827873"
|
|
||||||
|
|
||||||
assert returned_activity.data["object"]["inReplyToStatusId"] == activity.id
|
assert returned_object.data["inReplyToStatusId"] == activity.id
|
||||||
end
|
end
|
||||||
|
|
||||||
test "it works for incoming notices" do
|
test "it works for incoming notices" do
|
||||||
|
@ -72,7 +72,7 @@ test "it works for incoming notices" do
|
||||||
|
|
||||||
assert data["actor"] == "http://mastodon.example.org/users/admin"
|
assert data["actor"] == "http://mastodon.example.org/users/admin"
|
||||||
|
|
||||||
object = data["object"]
|
object = Object.normalize(data["object"]).data
|
||||||
assert object["id"] == "http://mastodon.example.org/users/admin/statuses/99512778738411822"
|
assert object["id"] == "http://mastodon.example.org/users/admin/statuses/99512778738411822"
|
||||||
|
|
||||||
assert object["to"] == ["https://www.w3.org/ns/activitystreams#Public"]
|
assert object["to"] == ["https://www.w3.org/ns/activitystreams#Public"]
|
||||||
|
@ -99,7 +99,9 @@ test "it works for incoming notices with hashtags" do
|
||||||
data = File.read!("test/fixtures/mastodon-post-activity-hashtag.json") |> Poison.decode!()
|
data = File.read!("test/fixtures/mastodon-post-activity-hashtag.json") |> Poison.decode!()
|
||||||
|
|
||||||
{:ok, %Activity{data: data, local: false}} = Transmogrifier.handle_incoming(data)
|
{:ok, %Activity{data: data, local: false}} = Transmogrifier.handle_incoming(data)
|
||||||
assert Enum.at(data["object"]["tag"], 2) == "moo"
|
object = Object.normalize(data["object"])
|
||||||
|
|
||||||
|
assert Enum.at(object.data["tag"], 2) == "moo"
|
||||||
end
|
end
|
||||||
|
|
||||||
test "it works for incoming notices with contentMap" do
|
test "it works for incoming notices with contentMap" do
|
||||||
|
@ -107,8 +109,9 @@ test "it works for incoming notices with contentMap" do
|
||||||
File.read!("test/fixtures/mastodon-post-activity-contentmap.json") |> Poison.decode!()
|
File.read!("test/fixtures/mastodon-post-activity-contentmap.json") |> Poison.decode!()
|
||||||
|
|
||||||
{:ok, %Activity{data: data, local: false}} = Transmogrifier.handle_incoming(data)
|
{:ok, %Activity{data: data, local: false}} = Transmogrifier.handle_incoming(data)
|
||||||
|
object = Object.normalize(data["object"])
|
||||||
|
|
||||||
assert data["object"]["content"] ==
|
assert object.data["content"] ==
|
||||||
"<p><span class=\"h-card\"><a href=\"http://localtesting.pleroma.lol/users/lain\" class=\"u-url mention\">@<span>lain</span></a></span></p>"
|
"<p><span class=\"h-card\"><a href=\"http://localtesting.pleroma.lol/users/lain\" class=\"u-url mention\">@<span>lain</span></a></span></p>"
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -116,8 +119,9 @@ test "it works for incoming notices with to/cc not being an array (kroeg)" do
|
||||||
data = File.read!("test/fixtures/kroeg-post-activity.json") |> Poison.decode!()
|
data = File.read!("test/fixtures/kroeg-post-activity.json") |> Poison.decode!()
|
||||||
|
|
||||||
{:ok, %Activity{data: data, local: false}} = Transmogrifier.handle_incoming(data)
|
{:ok, %Activity{data: data, local: false}} = Transmogrifier.handle_incoming(data)
|
||||||
|
object = Object.normalize(data["object"])
|
||||||
|
|
||||||
assert data["object"]["content"] ==
|
assert object.data["content"] ==
|
||||||
"<p>henlo from my Psion netBook</p><p>message sent from my Psion netBook</p>"
|
"<p>henlo from my Psion netBook</p><p>message sent from my Psion netBook</p>"
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -133,24 +137,27 @@ test "it works for incoming notices with tag not being an array (kroeg)" do
|
||||||
data = File.read!("test/fixtures/kroeg-array-less-emoji.json") |> Poison.decode!()
|
data = File.read!("test/fixtures/kroeg-array-less-emoji.json") |> Poison.decode!()
|
||||||
|
|
||||||
{:ok, %Activity{data: data, local: false}} = Transmogrifier.handle_incoming(data)
|
{:ok, %Activity{data: data, local: false}} = Transmogrifier.handle_incoming(data)
|
||||||
|
object = Object.normalize(data["object"])
|
||||||
|
|
||||||
assert data["object"]["emoji"] == %{
|
assert object.data["emoji"] == %{
|
||||||
"icon_e_smile" => "https://puckipedia.com/forum/images/smilies/icon_e_smile.png"
|
"icon_e_smile" => "https://puckipedia.com/forum/images/smilies/icon_e_smile.png"
|
||||||
}
|
}
|
||||||
|
|
||||||
data = File.read!("test/fixtures/kroeg-array-less-hashtag.json") |> Poison.decode!()
|
data = File.read!("test/fixtures/kroeg-array-less-hashtag.json") |> Poison.decode!()
|
||||||
|
|
||||||
{:ok, %Activity{data: data, local: false}} = Transmogrifier.handle_incoming(data)
|
{:ok, %Activity{data: data, local: false}} = Transmogrifier.handle_incoming(data)
|
||||||
|
object = Object.normalize(data["object"])
|
||||||
|
|
||||||
assert "test" in data["object"]["tag"]
|
assert "test" in object.data["tag"]
|
||||||
end
|
end
|
||||||
|
|
||||||
test "it works for incoming notices with url not being a string (prismo)" do
|
test "it works for incoming notices with url not being a string (prismo)" do
|
||||||
data = File.read!("test/fixtures/prismo-url-map.json") |> Poison.decode!()
|
data = File.read!("test/fixtures/prismo-url-map.json") |> Poison.decode!()
|
||||||
|
|
||||||
{:ok, %Activity{data: data, local: false}} = Transmogrifier.handle_incoming(data)
|
{:ok, %Activity{data: data, local: false}} = Transmogrifier.handle_incoming(data)
|
||||||
|
object = Object.normalize(data["object"])
|
||||||
|
|
||||||
assert data["object"]["url"] == "https://prismo.news/posts/83"
|
assert object.data["url"] == "https://prismo.news/posts/83"
|
||||||
end
|
end
|
||||||
|
|
||||||
test "it works for incoming follow requests" do
|
test "it works for incoming follow requests" do
|
||||||
|
@ -193,14 +200,14 @@ test "it works for incoming likes" do
|
||||||
data =
|
data =
|
||||||
File.read!("test/fixtures/mastodon-like.json")
|
File.read!("test/fixtures/mastodon-like.json")
|
||||||
|> Poison.decode!()
|
|> Poison.decode!()
|
||||||
|> Map.put("object", activity.data["object"]["id"])
|
|> Map.put("object", activity.data["object"])
|
||||||
|
|
||||||
{:ok, %Activity{data: data, local: false}} = Transmogrifier.handle_incoming(data)
|
{:ok, %Activity{data: data, local: false}} = Transmogrifier.handle_incoming(data)
|
||||||
|
|
||||||
assert data["actor"] == "http://mastodon.example.org/users/admin"
|
assert data["actor"] == "http://mastodon.example.org/users/admin"
|
||||||
assert data["type"] == "Like"
|
assert data["type"] == "Like"
|
||||||
assert data["id"] == "http://mastodon.example.org/users/admin#likes/2"
|
assert data["id"] == "http://mastodon.example.org/users/admin#likes/2"
|
||||||
assert data["object"] == activity.data["object"]["id"]
|
assert data["object"] == activity.data["object"]
|
||||||
end
|
end
|
||||||
|
|
||||||
test "it returns an error for incoming unlikes wihout a like activity" do
|
test "it returns an error for incoming unlikes wihout a like activity" do
|
||||||
|
@ -210,7 +217,7 @@ test "it returns an error for incoming unlikes wihout a like activity" do
|
||||||
data =
|
data =
|
||||||
File.read!("test/fixtures/mastodon-undo-like.json")
|
File.read!("test/fixtures/mastodon-undo-like.json")
|
||||||
|> Poison.decode!()
|
|> Poison.decode!()
|
||||||
|> Map.put("object", activity.data["object"]["id"])
|
|> Map.put("object", activity.data["object"])
|
||||||
|
|
||||||
assert Transmogrifier.handle_incoming(data) == :error
|
assert Transmogrifier.handle_incoming(data) == :error
|
||||||
end
|
end
|
||||||
|
@ -222,7 +229,7 @@ test "it works for incoming unlikes with an existing like activity" do
|
||||||
like_data =
|
like_data =
|
||||||
File.read!("test/fixtures/mastodon-like.json")
|
File.read!("test/fixtures/mastodon-like.json")
|
||||||
|> Poison.decode!()
|
|> Poison.decode!()
|
||||||
|> Map.put("object", activity.data["object"]["id"])
|
|> Map.put("object", activity.data["object"])
|
||||||
|
|
||||||
{:ok, %Activity{data: like_data, local: false}} = Transmogrifier.handle_incoming(like_data)
|
{:ok, %Activity{data: like_data, local: false}} = Transmogrifier.handle_incoming(like_data)
|
||||||
|
|
||||||
|
@ -264,7 +271,7 @@ test "it works for incoming announces with an existing activity" do
|
||||||
data =
|
data =
|
||||||
File.read!("test/fixtures/mastodon-announce.json")
|
File.read!("test/fixtures/mastodon-announce.json")
|
||||||
|> Poison.decode!()
|
|> Poison.decode!()
|
||||||
|> Map.put("object", activity.data["object"]["id"])
|
|> Map.put("object", activity.data["object"])
|
||||||
|
|
||||||
{:ok, %Activity{data: data, local: false}} = Transmogrifier.handle_incoming(data)
|
{:ok, %Activity{data: data, local: false}} = Transmogrifier.handle_incoming(data)
|
||||||
|
|
||||||
|
@ -274,7 +281,7 @@ test "it works for incoming announces with an existing activity" do
|
||||||
assert data["id"] ==
|
assert data["id"] ==
|
||||||
"http://mastodon.example.org/users/admin/statuses/99542391527669785/activity"
|
"http://mastodon.example.org/users/admin/statuses/99542391527669785/activity"
|
||||||
|
|
||||||
assert data["object"] == activity.data["object"]["id"]
|
assert data["object"] == activity.data["object"]
|
||||||
|
|
||||||
assert Activity.get_create_activity_by_object_ap_id(data["object"]).id == activity.id
|
assert Activity.get_create_activity_by_object_ap_id(data["object"]).id == activity.id
|
||||||
end
|
end
|
||||||
|
@ -349,7 +356,7 @@ test "it works for incoming deletes" do
|
||||||
|
|
||||||
object =
|
object =
|
||||||
data["object"]
|
data["object"]
|
||||||
|> Map.put("id", activity.data["object"]["id"])
|
|> Map.put("id", activity.data["object"])
|
||||||
|
|
||||||
data =
|
data =
|
||||||
data
|
data
|
||||||
|
@ -370,7 +377,7 @@ test "it fails for incoming deletes with spoofed origin" do
|
||||||
|
|
||||||
object =
|
object =
|
||||||
data["object"]
|
data["object"]
|
||||||
|> Map.put("id", activity.data["object"]["id"])
|
|> Map.put("id", activity.data["object"])
|
||||||
|
|
||||||
data =
|
data =
|
||||||
data
|
data
|
||||||
|
@ -388,7 +395,7 @@ test "it works for incoming unannounces with an existing notice" do
|
||||||
announce_data =
|
announce_data =
|
||||||
File.read!("test/fixtures/mastodon-announce.json")
|
File.read!("test/fixtures/mastodon-announce.json")
|
||||||
|> Poison.decode!()
|
|> Poison.decode!()
|
||||||
|> Map.put("object", activity.data["object"]["id"])
|
|> Map.put("object", activity.data["object"])
|
||||||
|
|
||||||
{:ok, %Activity{data: announce_data, local: false}} =
|
{:ok, %Activity{data: announce_data, local: false}} =
|
||||||
Transmogrifier.handle_incoming(announce_data)
|
Transmogrifier.handle_incoming(announce_data)
|
||||||
|
@ -403,7 +410,7 @@ test "it works for incoming unannounces with an existing notice" do
|
||||||
|
|
||||||
assert data["type"] == "Undo"
|
assert data["type"] == "Undo"
|
||||||
assert data["object"]["type"] == "Announce"
|
assert data["object"]["type"] == "Announce"
|
||||||
assert data["object"]["object"] == activity.data["object"]["id"]
|
assert data["object"]["object"] == activity.data["object"]
|
||||||
|
|
||||||
assert data["object"]["id"] ==
|
assert data["object"]["id"] ==
|
||||||
"http://mastodon.example.org/users/admin/statuses/99542391527669785/activity"
|
"http://mastodon.example.org/users/admin/statuses/99542391527669785/activity"
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
defmodule Pleroma.Web.CommonAPI.Test do
|
defmodule Pleroma.Web.CommonAPI.Test do
|
||||||
use Pleroma.DataCase
|
use Pleroma.DataCase
|
||||||
alias Pleroma.Web.CommonAPI
|
alias Pleroma.Web.CommonAPI
|
||||||
alias Pleroma.User
|
alias Pleroma.{User, Object}
|
||||||
|
|
||||||
import Pleroma.Factory
|
import Pleroma.Factory
|
||||||
|
|
||||||
|
@ -9,7 +9,9 @@ test "it de-duplicates tags" do
|
||||||
user = insert(:user)
|
user = insert(:user)
|
||||||
{:ok, activity} = CommonAPI.post(user, %{"status" => "#2hu #2HU"})
|
{:ok, activity} = CommonAPI.post(user, %{"status" => "#2hu #2HU"})
|
||||||
|
|
||||||
assert activity.data["object"]["tag"] == ["2hu"]
|
object = Object.normalize(activity.data["object"])
|
||||||
|
|
||||||
|
assert object.data["tag"] == ["2hu"]
|
||||||
end
|
end
|
||||||
|
|
||||||
test "it adds emoji when updating profiles" do
|
test "it adds emoji when updating profiles" do
|
||||||
|
@ -34,8 +36,10 @@ test "it filters out obviously bad tags when accepting a post as HTML" do
|
||||||
"content_type" => "text/html"
|
"content_type" => "text/html"
|
||||||
})
|
})
|
||||||
|
|
||||||
content = activity.data["object"]["content"]
|
object =
|
||||||
assert content == "<p><b>2hu</b></p>alert('xss')"
|
Object.normalize(activity.data["object"])
|
||||||
|
|
||||||
|
assert object.data["content"] == "<p><b>2hu</b></p>alert('xss')"
|
||||||
end
|
end
|
||||||
|
|
||||||
test "it filters out obviously bad tags when accepting a post as Markdown" do
|
test "it filters out obviously bad tags when accepting a post as Markdown" do
|
||||||
|
@ -49,8 +53,10 @@ test "it filters out obviously bad tags when accepting a post as Markdown" do
|
||||||
"content_type" => "text/markdown"
|
"content_type" => "text/markdown"
|
||||||
})
|
})
|
||||||
|
|
||||||
content = activity.data["object"]["content"]
|
object =
|
||||||
assert content == "<p><b>2hu</b></p>alert('xss')"
|
Object.normalize(activity.data["object"])
|
||||||
|
|
||||||
|
assert object.data["content"] == "<p><b>2hu</b></p>alert('xss')"
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -15,34 +15,36 @@ test "don't insert create notes twice" do
|
||||||
test "handle incoming note - GS, Salmon" do
|
test "handle incoming note - GS, Salmon" do
|
||||||
incoming = File.read!("test/fixtures/incoming_note_activity.xml")
|
incoming = File.read!("test/fixtures/incoming_note_activity.xml")
|
||||||
{:ok, [activity]} = OStatus.handle_incoming(incoming)
|
{:ok, [activity]} = OStatus.handle_incoming(incoming)
|
||||||
|
object = Object.normalize(activity.data["object"])
|
||||||
|
|
||||||
user = User.get_by_ap_id(activity.data["actor"])
|
user = User.get_by_ap_id(activity.data["actor"])
|
||||||
assert user.info.note_count == 1
|
assert user.info.note_count == 1
|
||||||
assert activity.data["type"] == "Create"
|
assert activity.data["type"] == "Create"
|
||||||
assert activity.data["object"]["type"] == "Note"
|
assert object.data["type"] == "Note"
|
||||||
|
|
||||||
assert activity.data["object"]["id"] ==
|
assert object.data["id"] ==
|
||||||
"tag:gs.example.org:4040,2017-04-23:noticeId=29:objectType=note"
|
"tag:gs.example.org:4040,2017-04-23:noticeId=29:objectType=note"
|
||||||
|
|
||||||
assert activity.data["published"] == "2017-04-23T14:51:03+00:00"
|
assert activity.data["published"] == "2017-04-23T14:51:03+00:00"
|
||||||
assert activity.data["object"]["published"] == "2017-04-23T14:51:03+00:00"
|
assert object.data["published"] == "2017-04-23T14:51:03+00:00"
|
||||||
|
|
||||||
assert activity.data["context"] ==
|
assert activity.data["context"] ==
|
||||||
"tag:gs.example.org:4040,2017-04-23:objectType=thread:nonce=f09e22f58abd5c7b"
|
"tag:gs.example.org:4040,2017-04-23:objectType=thread:nonce=f09e22f58abd5c7b"
|
||||||
|
|
||||||
assert "http://pleroma.example.org:4000/users/lain3" in activity.data["to"]
|
assert "http://pleroma.example.org:4000/users/lain3" in activity.data["to"]
|
||||||
assert activity.data["object"]["emoji"] == %{"marko" => "marko.png", "reimu" => "reimu.png"}
|
assert object.data["emoji"] == %{"marko" => "marko.png", "reimu" => "reimu.png"}
|
||||||
assert activity.local == false
|
assert activity.local == false
|
||||||
end
|
end
|
||||||
|
|
||||||
test "handle incoming notes - GS, subscription" do
|
test "handle incoming notes - GS, subscription" do
|
||||||
incoming = File.read!("test/fixtures/ostatus_incoming_post.xml")
|
incoming = File.read!("test/fixtures/ostatus_incoming_post.xml")
|
||||||
{:ok, [activity]} = OStatus.handle_incoming(incoming)
|
{:ok, [activity]} = OStatus.handle_incoming(incoming)
|
||||||
|
object = Object.normalize(activity.data["object"])
|
||||||
|
|
||||||
assert activity.data["type"] == "Create"
|
assert activity.data["type"] == "Create"
|
||||||
assert activity.data["object"]["type"] == "Note"
|
assert object.data["type"] == "Note"
|
||||||
assert activity.data["object"]["actor"] == "https://social.heldscal.la/user/23211"
|
assert object.data["actor"] == "https://social.heldscal.la/user/23211"
|
||||||
assert activity.data["object"]["content"] == "Will it blend?"
|
assert object.data["content"] == "Will it blend?"
|
||||||
user = User.get_cached_by_ap_id(activity.data["actor"])
|
user = User.get_cached_by_ap_id(activity.data["actor"])
|
||||||
assert User.ap_followers(user) in activity.data["to"]
|
assert User.ap_followers(user) in activity.data["to"]
|
||||||
assert "https://www.w3.org/ns/activitystreams#Public" in activity.data["to"]
|
assert "https://www.w3.org/ns/activitystreams#Public" in activity.data["to"]
|
||||||
|
@ -51,20 +53,22 @@ test "handle incoming notes - GS, subscription" do
|
||||||
test "handle incoming notes with attachments - GS, subscription" do
|
test "handle incoming notes with attachments - GS, subscription" do
|
||||||
incoming = File.read!("test/fixtures/incoming_websub_gnusocial_attachments.xml")
|
incoming = File.read!("test/fixtures/incoming_websub_gnusocial_attachments.xml")
|
||||||
{:ok, [activity]} = OStatus.handle_incoming(incoming)
|
{:ok, [activity]} = OStatus.handle_incoming(incoming)
|
||||||
|
object = Object.normalize(activity.data["object"])
|
||||||
|
|
||||||
assert activity.data["type"] == "Create"
|
assert activity.data["type"] == "Create"
|
||||||
assert activity.data["object"]["type"] == "Note"
|
assert object.data["type"] == "Note"
|
||||||
assert activity.data["object"]["actor"] == "https://social.heldscal.la/user/23211"
|
assert object.data["actor"] == "https://social.heldscal.la/user/23211"
|
||||||
assert activity.data["object"]["attachment"] |> length == 2
|
assert object.data["attachment"] |> length == 2
|
||||||
assert activity.data["object"]["external_url"] == "https://social.heldscal.la/notice/2020923"
|
assert object.data["external_url"] == "https://social.heldscal.la/notice/2020923"
|
||||||
assert "https://www.w3.org/ns/activitystreams#Public" in activity.data["to"]
|
assert "https://www.w3.org/ns/activitystreams#Public" in activity.data["to"]
|
||||||
end
|
end
|
||||||
|
|
||||||
test "handle incoming notes with tags" do
|
test "handle incoming notes with tags" do
|
||||||
incoming = File.read!("test/fixtures/ostatus_incoming_post_tag.xml")
|
incoming = File.read!("test/fixtures/ostatus_incoming_post_tag.xml")
|
||||||
{:ok, [activity]} = OStatus.handle_incoming(incoming)
|
{:ok, [activity]} = OStatus.handle_incoming(incoming)
|
||||||
|
object = Object.normalize(activity.data["object"])
|
||||||
|
|
||||||
assert activity.data["object"]["tag"] == ["nsfw"]
|
assert object.data["tag"] == ["nsfw"]
|
||||||
assert "https://www.w3.org/ns/activitystreams#Public" in activity.data["to"]
|
assert "https://www.w3.org/ns/activitystreams#Public" in activity.data["to"]
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -79,10 +83,11 @@ test "handle incoming notes - Mastodon, salmon, reply" do
|
||||||
|
|
||||||
incoming = File.read!("test/fixtures/incoming_reply_mastodon.xml")
|
incoming = File.read!("test/fixtures/incoming_reply_mastodon.xml")
|
||||||
{:ok, [activity]} = OStatus.handle_incoming(incoming)
|
{:ok, [activity]} = OStatus.handle_incoming(incoming)
|
||||||
|
object = Object.normalize(activity.data["object"])
|
||||||
|
|
||||||
assert activity.data["type"] == "Create"
|
assert activity.data["type"] == "Create"
|
||||||
assert activity.data["object"]["type"] == "Note"
|
assert object.data["type"] == "Note"
|
||||||
assert activity.data["object"]["actor"] == "https://mastodon.social/users/lambadalambda"
|
assert object.data["actor"] == "https://mastodon.social/users/lambadalambda"
|
||||||
assert activity.data["context"] == "2hu"
|
assert activity.data["context"] == "2hu"
|
||||||
assert "https://www.w3.org/ns/activitystreams#Public" in activity.data["to"]
|
assert "https://www.w3.org/ns/activitystreams#Public" in activity.data["to"]
|
||||||
end
|
end
|
||||||
|
@ -90,42 +95,47 @@ test "handle incoming notes - Mastodon, salmon, reply" do
|
||||||
test "handle incoming notes - Mastodon, with CW" do
|
test "handle incoming notes - Mastodon, with CW" do
|
||||||
incoming = File.read!("test/fixtures/mastodon-note-cw.xml")
|
incoming = File.read!("test/fixtures/mastodon-note-cw.xml")
|
||||||
{:ok, [activity]} = OStatus.handle_incoming(incoming)
|
{:ok, [activity]} = OStatus.handle_incoming(incoming)
|
||||||
|
object = Object.normalize(activity.data["object"])
|
||||||
|
|
||||||
assert activity.data["type"] == "Create"
|
assert activity.data["type"] == "Create"
|
||||||
assert activity.data["object"]["type"] == "Note"
|
assert object.data["type"] == "Note"
|
||||||
assert activity.data["object"]["actor"] == "https://mastodon.social/users/lambadalambda"
|
assert object.data["actor"] == "https://mastodon.social/users/lambadalambda"
|
||||||
assert activity.data["object"]["summary"] == "technologic"
|
assert object.data["summary"] == "technologic"
|
||||||
assert "https://www.w3.org/ns/activitystreams#Public" in activity.data["to"]
|
assert "https://www.w3.org/ns/activitystreams#Public" in activity.data["to"]
|
||||||
end
|
end
|
||||||
|
|
||||||
test "handle incoming unlisted messages, put public into cc" do
|
test "handle incoming unlisted messages, put public into cc" do
|
||||||
incoming = File.read!("test/fixtures/mastodon-note-unlisted.xml")
|
incoming = File.read!("test/fixtures/mastodon-note-unlisted.xml")
|
||||||
{:ok, [activity]} = OStatus.handle_incoming(incoming)
|
{:ok, [activity]} = OStatus.handle_incoming(incoming)
|
||||||
|
object = Object.normalize(activity.data["object"])
|
||||||
|
|
||||||
refute "https://www.w3.org/ns/activitystreams#Public" in activity.data["to"]
|
refute "https://www.w3.org/ns/activitystreams#Public" in activity.data["to"]
|
||||||
assert "https://www.w3.org/ns/activitystreams#Public" in activity.data["cc"]
|
assert "https://www.w3.org/ns/activitystreams#Public" in activity.data["cc"]
|
||||||
refute "https://www.w3.org/ns/activitystreams#Public" in activity.data["object"]["to"]
|
refute "https://www.w3.org/ns/activitystreams#Public" in object.data["to"]
|
||||||
assert "https://www.w3.org/ns/activitystreams#Public" in activity.data["object"]["cc"]
|
assert "https://www.w3.org/ns/activitystreams#Public" in object.data["cc"]
|
||||||
end
|
end
|
||||||
|
|
||||||
test "handle incoming retweets - Mastodon, with CW" do
|
test "handle incoming retweets - Mastodon, with CW" do
|
||||||
incoming = File.read!("test/fixtures/cw_retweet.xml")
|
incoming = File.read!("test/fixtures/cw_retweet.xml")
|
||||||
{:ok, [[_activity, retweeted_activity]]} = OStatus.handle_incoming(incoming)
|
{:ok, [[_activity, retweeted_activity]]} = OStatus.handle_incoming(incoming)
|
||||||
|
retweeted_object = Object.normalize(retweeted_activity.data["object"])
|
||||||
|
|
||||||
assert retweeted_activity.data["object"]["summary"] == "Hey."
|
assert retweeted_object.data["summary"] == "Hey."
|
||||||
end
|
end
|
||||||
|
|
||||||
test "handle incoming notes - GS, subscription, reply" do
|
test "handle incoming notes - GS, subscription, reply" do
|
||||||
incoming = File.read!("test/fixtures/ostatus_incoming_reply.xml")
|
incoming = File.read!("test/fixtures/ostatus_incoming_reply.xml")
|
||||||
{:ok, [activity]} = OStatus.handle_incoming(incoming)
|
{:ok, [activity]} = OStatus.handle_incoming(incoming)
|
||||||
|
object = Object.normalize(activity.data["object"])
|
||||||
|
|
||||||
assert activity.data["type"] == "Create"
|
assert activity.data["type"] == "Create"
|
||||||
assert activity.data["object"]["type"] == "Note"
|
assert object.data["type"] == "Note"
|
||||||
assert activity.data["object"]["actor"] == "https://social.heldscal.la/user/23211"
|
assert object.data["actor"] == "https://social.heldscal.la/user/23211"
|
||||||
|
|
||||||
assert activity.data["object"]["content"] ==
|
assert object.data["content"] ==
|
||||||
"@<a href=\"https://gs.archae.me/user/4687\" class=\"h-card u-url p-nickname mention\" title=\"shpbot\">shpbot</a> why not indeed."
|
"@<a href=\"https://gs.archae.me/user/4687\" class=\"h-card u-url p-nickname mention\" title=\"shpbot\">shpbot</a> why not indeed."
|
||||||
|
|
||||||
assert activity.data["object"]["inReplyTo"] ==
|
assert object.data["inReplyTo"] ==
|
||||||
"tag:gs.archae.me,2017-04-30:noticeId=778260:objectType=note"
|
"tag:gs.archae.me,2017-04-30:noticeId=778260:objectType=note"
|
||||||
|
|
||||||
assert "https://www.w3.org/ns/activitystreams#Public" in activity.data["to"]
|
assert "https://www.w3.org/ns/activitystreams#Public" in activity.data["to"]
|
||||||
|
@ -137,17 +147,19 @@ test "handle incoming retweets - GS, subscription" do
|
||||||
|
|
||||||
assert activity.data["type"] == "Announce"
|
assert activity.data["type"] == "Announce"
|
||||||
assert activity.data["actor"] == "https://social.heldscal.la/user/23211"
|
assert activity.data["actor"] == "https://social.heldscal.la/user/23211"
|
||||||
assert activity.data["object"] == retweeted_activity.data["object"]["id"]
|
assert activity.data["object"] == retweeted_activity.data["object"]
|
||||||
assert "https://pleroma.soykaf.com/users/lain" in activity.data["to"]
|
assert "https://pleroma.soykaf.com/users/lain" in activity.data["to"]
|
||||||
refute activity.local
|
refute activity.local
|
||||||
|
|
||||||
retweeted_activity = Repo.get(Activity, retweeted_activity.id)
|
retweeted_activity = Repo.get(Activity, retweeted_activity.id)
|
||||||
|
retweeted_object = Object.normalize(retweeted_activity.data["object"])
|
||||||
|
|
||||||
assert retweeted_activity.data["type"] == "Create"
|
assert retweeted_activity.data["type"] == "Create"
|
||||||
assert retweeted_activity.data["actor"] == "https://pleroma.soykaf.com/users/lain"
|
assert retweeted_activity.data["actor"] == "https://pleroma.soykaf.com/users/lain"
|
||||||
refute retweeted_activity.local
|
refute retweeted_activity.local
|
||||||
assert retweeted_activity.data["object"]["announcement_count"] == 1
|
assert retweeted_object.data["announcement_count"] == 1
|
||||||
assert String.contains?(retweeted_activity.data["object"]["content"], "mastodon")
|
assert String.contains?(retweeted_object.data["content"], "mastodon")
|
||||||
refute String.contains?(retweeted_activity.data["object"]["content"], "Test account")
|
refute String.contains?(retweeted_object.data["content"], "Test account")
|
||||||
end
|
end
|
||||||
|
|
||||||
test "handle incoming retweets - GS, subscription - local message" do
|
test "handle incoming retweets - GS, subscription - local message" do
|
||||||
|
@ -179,10 +191,11 @@ test "handle incoming retweets - GS, subscription - local message" do
|
||||||
test "handle incoming retweets - Mastodon, salmon" do
|
test "handle incoming retweets - Mastodon, salmon" do
|
||||||
incoming = File.read!("test/fixtures/share.xml")
|
incoming = File.read!("test/fixtures/share.xml")
|
||||||
{:ok, [[activity, retweeted_activity]]} = OStatus.handle_incoming(incoming)
|
{:ok, [[activity, retweeted_activity]]} = OStatus.handle_incoming(incoming)
|
||||||
|
retweeted_object = Object.normalize(retweeted_activity.data["object"])
|
||||||
|
|
||||||
assert activity.data["type"] == "Announce"
|
assert activity.data["type"] == "Announce"
|
||||||
assert activity.data["actor"] == "https://mastodon.social/users/lambadalambda"
|
assert activity.data["actor"] == "https://mastodon.social/users/lambadalambda"
|
||||||
assert activity.data["object"] == retweeted_activity.data["object"]["id"]
|
assert activity.data["object"] == retweeted_activity.data["object"]
|
||||||
|
|
||||||
assert activity.data["id"] ==
|
assert activity.data["id"] ==
|
||||||
"tag:mastodon.social,2017-05-03:objectId=4934452:objectType=Status"
|
"tag:mastodon.social,2017-05-03:objectId=4934452:objectType=Status"
|
||||||
|
@ -191,7 +204,7 @@ test "handle incoming retweets - Mastodon, salmon" do
|
||||||
assert retweeted_activity.data["type"] == "Create"
|
assert retweeted_activity.data["type"] == "Create"
|
||||||
assert retweeted_activity.data["actor"] == "https://pleroma.soykaf.com/users/lain"
|
assert retweeted_activity.data["actor"] == "https://pleroma.soykaf.com/users/lain"
|
||||||
refute retweeted_activity.local
|
refute retweeted_activity.local
|
||||||
refute String.contains?(retweeted_activity.data["object"]["content"], "Test account")
|
refute String.contains?(retweeted_object.data["content"], "Test account")
|
||||||
end
|
end
|
||||||
|
|
||||||
test "handle incoming favorites - GS, websub" do
|
test "handle incoming favorites - GS, websub" do
|
||||||
|
@ -201,7 +214,7 @@ test "handle incoming favorites - GS, websub" do
|
||||||
|
|
||||||
assert activity.data["type"] == "Like"
|
assert activity.data["type"] == "Like"
|
||||||
assert activity.data["actor"] == "https://social.heldscal.la/user/23211"
|
assert activity.data["actor"] == "https://social.heldscal.la/user/23211"
|
||||||
assert activity.data["object"] == favorited_activity.data["object"]["id"]
|
assert activity.data["object"] == favorited_activity.data["object"]
|
||||||
|
|
||||||
assert activity.data["id"] ==
|
assert activity.data["id"] ==
|
||||||
"tag:social.heldscal.la,2017-05-05:fave:23211:comment:2061643:2017-05-05T09:12:50+00:00"
|
"tag:social.heldscal.la,2017-05-05:fave:23211:comment:2061643:2017-05-05T09:12:50+00:00"
|
||||||
|
@ -210,7 +223,7 @@ test "handle incoming favorites - GS, websub" do
|
||||||
assert favorited_activity.data["type"] == "Create"
|
assert favorited_activity.data["type"] == "Create"
|
||||||
assert favorited_activity.data["actor"] == "https://shitposter.club/user/1"
|
assert favorited_activity.data["actor"] == "https://shitposter.club/user/1"
|
||||||
|
|
||||||
assert favorited_activity.data["object"]["id"] ==
|
assert favorited_activity.data["object"] ==
|
||||||
"tag:shitposter.club,2017-05-05:noticeId=2827873:objectType=comment"
|
"tag:shitposter.club,2017-05-05:noticeId=2827873:objectType=comment"
|
||||||
|
|
||||||
refute favorited_activity.local
|
refute favorited_activity.local
|
||||||
|
@ -245,16 +258,17 @@ test "handle incoming favorites with locally available object - GS, websub" do
|
||||||
test "handle incoming replies" do
|
test "handle incoming replies" do
|
||||||
incoming = File.read!("test/fixtures/incoming_note_activity_answer.xml")
|
incoming = File.read!("test/fixtures/incoming_note_activity_answer.xml")
|
||||||
{:ok, [activity]} = OStatus.handle_incoming(incoming)
|
{:ok, [activity]} = OStatus.handle_incoming(incoming)
|
||||||
|
object = Object.normalize(activity.data["object"])
|
||||||
|
|
||||||
assert activity.data["type"] == "Create"
|
assert activity.data["type"] == "Create"
|
||||||
assert activity.data["object"]["type"] == "Note"
|
assert object.data["type"] == "Note"
|
||||||
|
|
||||||
assert activity.data["object"]["inReplyTo"] ==
|
assert object.data["inReplyTo"] ==
|
||||||
"http://pleroma.example.org:4000/objects/55bce8fc-b423-46b1-af71-3759ab4670bc"
|
"http://pleroma.example.org:4000/objects/55bce8fc-b423-46b1-af71-3759ab4670bc"
|
||||||
|
|
||||||
assert "http://pleroma.example.org:4000/users/lain5" in activity.data["to"]
|
assert "http://pleroma.example.org:4000/users/lain5" in activity.data["to"]
|
||||||
|
|
||||||
assert activity.data["object"]["id"] ==
|
assert object.data["id"] ==
|
||||||
"tag:gs.example.org:4040,2017-04-25:noticeId=55:objectType=note"
|
"tag:gs.example.org:4040,2017-04-25:noticeId=55:objectType=note"
|
||||||
|
|
||||||
assert "https://www.w3.org/ns/activitystreams#Public" in activity.data["to"]
|
assert "https://www.w3.org/ns/activitystreams#Public" in activity.data["to"]
|
||||||
|
@ -466,7 +480,7 @@ test "it builds a missing status from an html url" do
|
||||||
|
|
||||||
assert activity.data["actor"] == "https://shitposter.club/user/1"
|
assert activity.data["actor"] == "https://shitposter.club/user/1"
|
||||||
|
|
||||||
assert activity.data["object"]["id"] ==
|
assert activity.data["object"] ==
|
||||||
"tag:shitposter.club,2017-05-05:noticeId=2827873:objectType=comment"
|
"tag:shitposter.club,2017-05-05:noticeId=2827873:objectType=comment"
|
||||||
end)
|
end)
|
||||||
end
|
end
|
||||||
|
@ -475,7 +489,7 @@ test "it works for atom notes, too" do
|
||||||
url = "https://social.sakamoto.gq/objects/0ccc1a2c-66b0-4305-b23a-7f7f2b040056"
|
url = "https://social.sakamoto.gq/objects/0ccc1a2c-66b0-4305-b23a-7f7f2b040056"
|
||||||
{:ok, [activity]} = OStatus.fetch_activity_from_url(url)
|
{:ok, [activity]} = OStatus.fetch_activity_from_url(url)
|
||||||
assert activity.data["actor"] == "https://social.sakamoto.gq/users/eal"
|
assert activity.data["actor"] == "https://social.sakamoto.gq/users/eal"
|
||||||
assert activity.data["object"]["id"] == url
|
assert activity.data["object"] == url
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue