aboutsummaryrefslogtreecommitdiff
path: root/test/web/twitter_api/representers/activity_representer_test.exs
diff options
context:
space:
mode:
Diffstat (limited to 'test/web/twitter_api/representers/activity_representer_test.exs')
-rw-r--r--test/web/twitter_api/representers/activity_representer_test.exs49
1 files changed, 47 insertions, 2 deletions
diff --git a/test/web/twitter_api/representers/activity_representer_test.exs b/test/web/twitter_api/representers/activity_representer_test.exs
index f1f2b4c9c..a9129bccc 100644
--- a/test/web/twitter_api/representers/activity_representer_test.exs
+++ b/test/web/twitter_api/representers/activity_representer_test.exs
@@ -2,7 +2,46 @@ defmodule Pleroma.Web.TwitterAPI.Representers.ActivityRepresenterTest do
use Pleroma.DataCase
alias Pleroma.{User, Activity, Object}
alias Pleroma.Web.TwitterAPI.Representers.{UserRepresenter, ActivityRepresenter, ObjectRepresenter}
+ alias Pleroma.Web.ActivityPub.ActivityPub
alias Pleroma.Builders.UserBuilder
+ import Pleroma.Factory
+
+ 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
+ assert status["user"] == UserRepresenter.to_map(user, %{for: user})
+
+ retweeted_status = ActivityRepresenter.to_map(note_activity, %{user: activity_actor, for: user})
+ assert retweeted_status["repeated"] == true
+
+ assert status["retweeted_status"] == retweeted_status
+ end
+
+ 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)
+ 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
+ end
test "an activity" do
{:ok, user} = UserBuilder.insert
@@ -45,7 +84,9 @@ defmodule Pleroma.Web.TwitterAPI.Representers.ActivityRepresenterTest do
"statusnetConversationId" => 4711,
"attachment" => [
object
- ]
+ ],
+ "like_count" => 5,
+ "announcement_count" => 3
},
"published" => date
}
@@ -68,7 +109,11 @@ defmodule Pleroma.Web.TwitterAPI.Representers.ActivityRepresenterTest do
],
"attentions" => [
UserRepresenter.to_map(mentioned_user, %{for: follower})
- ]
+ ],
+ "fave_num" => 5,
+ "repeat_num" => 3,
+ "favorited" => false,
+ "repeated" => false
}
assert ActivityRepresenter.to_map(activity, %{user: user, for: follower, mentioned: [mentioned_user]}) == expected_status