pleroma/test/web/twitter_api/representers/activity_representer_test.exs

147 lines
5.1 KiB
Elixir
Raw Normal View History

2017-03-21 09:53:20 -07:00
defmodule Pleroma.Web.TwitterAPI.Representers.ActivityRepresenterTest do
use Pleroma.DataCase
2017-03-30 08:07:03 -07:00
alias Pleroma.{User, Activity, Object}
2017-06-19 14:12:37 -07:00
alias Pleroma.Web.TwitterAPI.Representers.{ActivityRepresenter, ObjectRepresenter}
2017-04-13 08:05:53 -07:00
alias Pleroma.Web.ActivityPub.ActivityPub
2017-03-21 09:53:20 -07:00
alias Pleroma.Builders.UserBuilder
2017-06-19 14:12:37 -07:00
alias Pleroma.Web.TwitterAPI.UserView
2017-04-13 08:05:53 -07:00
import Pleroma.Factory
2017-04-15 04:54:46 -07:00
test "an announce activity" do
user = insert(:user)
note_activity = insert(:note_activity)
activity_actor = Repo.get_by(User, ap_id: note_activity.data["actor"])
object = Object.get_by_ap_id(note_activity.data["object"]["id"])
{:ok, announce_activity, _object} = ActivityPub.announce(user, object)
note_activity = Activity.get_by_ap_id(note_activity.data["id"])
status = ActivityRepresenter.to_map(announce_activity, %{users: [user, activity_actor], announced_activity: note_activity, for: user})
assert status["id"] == announce_activity.id
2017-06-19 14:12:37 -07:00
assert status["user"] == UserView.render("show.json", %{user: user, for: user})
2017-04-15 04:54:46 -07:00
retweeted_status = ActivityRepresenter.to_map(note_activity, %{user: activity_actor, for: user})
assert retweeted_status["repeated"] == true
assert retweeted_status["id"] == note_activity.id
assert status["statusnet_conversation_id"] == retweeted_status["statusnet_conversation_id"]
2017-04-15 04:54:46 -07:00
assert status["retweeted_status"] == retweeted_status
end
2017-04-13 08:05:53 -07:00
test "a like activity" do
user = insert(:user)
note_activity = insert(:note_activity)
object = Object.get_by_ap_id(note_activity.data["object"]["id"])
{:ok, like_activity, _object} = ActivityPub.like(user, object)
2017-04-13 08:05:53 -07:00
status = ActivityRepresenter.to_map(like_activity, %{user: user, liked_activity: note_activity})
assert status["id"] == like_activity.id
assert status["in_reply_to_status_id"] == note_activity.id
note_activity = Activity.get_by_ap_id(note_activity.data["id"])
activity_actor = Repo.get_by(User, ap_id: note_activity.data["actor"])
liked_status = ActivityRepresenter.to_map(note_activity, %{user: activity_actor, for: user})
assert liked_status["favorited"] == true
2017-04-13 08:05:53 -07:00
end
2017-03-21 09:53:20 -07:00
test "an activity" do
{:ok, user} = UserBuilder.insert
2017-04-16 06:28:28 -07:00
# {:ok, mentioned_user } = UserBuilder.insert(%{nickname: "shp", ap_id: "shp"})
mentioned_user = insert(:user, %{nickname: "shp"})
# {:ok, follower} = UserBuilder.insert(%{following: [User.ap_followers(user)]})
follower = insert(:user, %{following: [User.ap_followers(user)]})
2017-03-30 08:07:03 -07:00
object = %Object{
data: %{
"type" => "Image",
"url" => [
%{
"type" => "Link",
"mediaType" => "image/jpg",
"href" => "http://example.org/image.jpg"
}
],
"uuid" => 1
}
}
content_html = "<script>alert('YAY')</script>Some content mentioning <a href='#{mentioned_user.ap_id}'>@shp</shp>"
2017-04-12 08:22:29 -07:00
content = HtmlSanitizeEx.strip_tags(content_html)
2017-04-12 10:34:58 -07:00
date = DateTime.from_naive!(~N[2016-05-24 13:26:08.003], "Etc/UTC") |> DateTime.to_iso8601
2017-03-22 08:51:20 -07:00
{:ok, convo_object} = Object.context_mapping("2hu") |> Repo.insert
2017-03-21 09:53:20 -07:00
activity = %Activity{
id: 1,
data: %{
"type" => "Create",
2017-05-07 11:20:53 -07:00
"id" => "id",
2017-03-21 09:53:20 -07:00
"to" => [
User.ap_followers(user),
"https://www.w3.org/ns/activitystreams#Public",
mentioned_user.ap_id
2017-03-21 09:53:20 -07:00
],
"actor" => User.ap_id(user),
"object" => %{
2017-03-22 08:51:20 -07:00
"published" => date,
2017-03-21 09:53:20 -07:00
"type" => "Note",
2017-04-12 08:22:29 -07:00
"content" => content_html,
"inReplyToStatusId" => 213123,
"attachment" => [
object
2017-04-13 07:19:07 -07:00
],
2017-06-25 03:07:08 -07:00
"external_url" => "some url",
2017-04-15 04:54:46 -07:00
"like_count" => 5,
"announcement_count" => 3,
2017-05-18 07:24:41 -07:00
"context" => "2hu",
2017-05-18 07:41:16 -07:00
"tag" => ["content", "mentioning", "nsfw"]
2017-03-22 08:51:20 -07:00
},
"published" => date,
"context" => "2hu"
2017-06-25 03:07:08 -07:00
},
local: false
2017-03-21 09:53:20 -07:00
}
expected_status = %{
"id" => activity.id,
2017-06-19 14:12:37 -07:00
"user" => UserView.render("show.json", %{user: user, for: follower}),
2017-06-25 03:07:08 -07:00
"is_local" => false,
"statusnet_html" => HtmlSanitizeEx.basic_html(content_html),
"text" => content,
2017-03-22 08:51:20 -07:00
"is_post_verb" => true,
2017-04-12 10:34:58 -07:00
"created_at" => "Tue May 24 13:26:08 +0000 2016",
"in_reply_to_status_id" => 213123,
"statusnet_conversation_id" => convo_object.id,
2017-03-30 08:07:03 -07:00
"attachments" => [
ObjectRepresenter.to_map(object)
],
"attentions" => [
2017-06-19 14:12:37 -07:00
UserView.render("show.json", %{user: mentioned_user, for: follower})
2017-04-13 07:19:07 -07:00
],
"fave_num" => 5,
2017-04-15 04:54:46 -07:00
"repeat_num" => 3,
"favorited" => false,
2017-05-07 11:20:53 -07:00
"repeated" => false,
2017-06-25 03:07:08 -07:00
"external_url" => "some url",
2017-06-18 05:43:44 -07:00
"tags" => ["content", "mentioning", "nsfw"]
2017-03-21 09:53:20 -07:00
}
assert ActivityRepresenter.to_map(activity, %{user: user, for: follower, mentioned: [mentioned_user]}) == expected_status
2017-03-21 09:53:20 -07:00
end
2017-07-08 02:17:35 -07:00
test "an undo for a follow" do
follower = insert(:user)
followed = insert(:user)
{:ok, follow} = ActivityPub.follow(follower, followed)
{:ok, unfollow} = ActivityPub.unfollow(follower, followed)
map = ActivityRepresenter.to_map(unfollow, %{user: follower})
assert map["is_post_verb"] == false
end
2017-03-21 09:53:20 -07:00
end