X-Git-Url: http://git.squeep.com/?a=blobdiff_plain;f=test%2Fweb%2Fostatus%2Factivity_representer_test.exs;h=969b2a854cf193f5880b83b189ad5240045f2662;hb=dd12cf7296566be206ca17044281ab2460fb7b9e;hp=6344889b1a82e14fab46018e5cb3bfe5f53d2d2b;hpb=62607f37dcf3ab149baa09fe144959a25322be69;p=akkoma
diff --git a/test/web/ostatus/activity_representer_test.exs b/test/web/ostatus/activity_representer_test.exs
index 6344889b1..969b2a854 100644
--- a/test/web/ostatus/activity_representer_test.exs
+++ b/test/web/ostatus/activity_representer_test.exs
@@ -2,7 +2,8 @@ defmodule Pleroma.Web.OStatus.ActivityRepresenterTest do
use Pleroma.DataCase
alias Pleroma.Web.OStatus.ActivityRepresenter
- alias Pleroma.{User, Activity}
+ alias Pleroma.{User, Activity, Object}
+ alias Pleroma.Web.ActivityPub.ActivityPub
import Pleroma.Factory
@@ -25,6 +26,8 @@ defmodule Pleroma.Web.OStatus.ActivityRepresenterTest do
#{updated_at}
#{note_activity.data["context"]}
+
+
"""
tuple = ActivityRepresenter.to_simple_form(note_activity, user)
@@ -60,7 +63,9 @@ defmodule Pleroma.Web.OStatus.ActivityRepresenterTest do
#{updated_at}
#{answer.data["context"]}
+
+
"""
tuple = ActivityRepresenter.to_simple_form(answer, user)
@@ -70,6 +75,168 @@ defmodule Pleroma.Web.OStatus.ActivityRepresenterTest do
assert clean(res) == clean(expected)
end
+ test "an announce activity" do
+ note = insert(:note_activity)
+ user = insert(:user)
+ object = Object.get_cached_by_ap_id(note.data["object"]["id"])
+
+ {:ok, announce, object} = ActivityPub.announce(user, object)
+
+ announce = Repo.get(Activity, announce.id)
+
+ note_user = User.get_cached_by_ap_id(note.data["actor"])
+ note = Repo.get(Activity, note.id)
+ note_xml = ActivityRepresenter.to_simple_form(note, note_user, true)
+ |> :xmerl.export_simple_content(:xmerl_xml)
+ |> to_string
+
+ updated_at = announce.updated_at
+ |> NaiveDateTime.to_iso8601
+ inserted_at = announce.inserted_at
+ |> NaiveDateTime.to_iso8601
+
+ expected = """
+ http://activitystrea.ms/schema/1.0/activity
+ http://activitystrea.ms/schema/1.0/share
+ #{announce.data["id"]}
+
#{user.nickname} repeated a notice
+ RT #{note.data["object"]["content"]}
+ #{inserted_at}
+ #{updated_at}
+ #{announce.data["context"]}
+
+
+
+ #{note_xml}
+
+
+ """
+
+ announce_xml = ActivityRepresenter.to_simple_form(announce, user)
+ |> :xmerl.export_simple_content(:xmerl_xml)
+ |> to_string
+
+ assert clean(expected) == clean(announce_xml)
+ end
+
+ test "a like activity" do
+ note = insert(:note)
+ user = insert(:user)
+ {:ok, like, _note} = ActivityPub.like(user, note)
+
+ # TODO: Are these the correct dates?
+ updated_at = like.updated_at
+ |> NaiveDateTime.to_iso8601
+ inserted_at = like.inserted_at
+ |> NaiveDateTime.to_iso8601
+
+ tuple = ActivityRepresenter.to_simple_form(like, user)
+ refute is_nil(tuple)
+
+ res = :xmerl.export_simple_content(tuple, :xmerl_xml) |> IO.iodata_to_binary
+
+ expected = """
+ http://activitystrea.ms/schema/1.0/favorite
+ #{like.data["id"]}
+ New favorite by #{user.nickname}
+ #{user.nickname} favorited something
+ #{inserted_at}
+ #{updated_at}
+
+ http://activitystrea.ms/schema/1.0/note
+ #{note.data["id"]}
+
+ #{like.data["context"]}
+
+
+
+
+ """
+
+ assert clean(res) == clean(expected)
+ end
+
+ test "a follow activity" do
+ follower = insert(:user)
+ followed = insert(:user)
+ {:ok, activity} = ActivityPub.insert(%{
+ "type" => "Follow",
+ "actor" => follower.ap_id,
+ "object" => followed.ap_id,
+ "to" => [followed.ap_id]
+ })
+
+
+ # TODO: Are these the correct dates?
+ updated_at = activity.updated_at
+ |> NaiveDateTime.to_iso8601
+ inserted_at = activity.inserted_at
+ |> NaiveDateTime.to_iso8601
+
+ tuple = ActivityRepresenter.to_simple_form(activity, follower)
+
+ refute is_nil(tuple)
+
+ res = :xmerl.export_simple_content(tuple, :xmerl_xml) |> IO.iodata_to_binary
+
+ expected = """
+ http://activitystrea.ms/schema/1.0/activity
+ http://activitystrea.ms/schema/1.0/follow
+ #{activity.data["id"]}
+ #{follower.nickname} started following #{activity.data["object"]}
+ #{follower.nickname} started following #{activity.data["object"]}
+ #{inserted_at}
+ #{updated_at}
+
+ http://activitystrea.ms/schema/1.0/person
+ #{activity.data["object"]}
+ #{activity.data["object"]}
+
+
+
+ """
+
+ assert clean(res) == clean(expected)
+ end
+
+ test "an unfollow activity" do
+ follower = insert(:user)
+ followed = insert(:user)
+ {:ok, _activity} = ActivityPub.follow(follower, followed)
+ {:ok, activity} = ActivityPub.unfollow(follower, followed)
+
+ # TODO: Are these the correct dates?
+ updated_at = activity.updated_at
+ |> NaiveDateTime.to_iso8601
+ inserted_at = activity.inserted_at
+ |> NaiveDateTime.to_iso8601
+
+ tuple = ActivityRepresenter.to_simple_form(activity, follower)
+
+ refute is_nil(tuple)
+
+ res = :xmerl.export_simple_content(tuple, :xmerl_xml) |> IO.iodata_to_binary
+
+ expected = """
+ http://activitystrea.ms/schema/1.0/activity
+ http://activitystrea.ms/schema/1.0/unfollow
+ #{activity.data["id"]}
+ #{follower.nickname} stopped following #{followed.ap_id}
+ #{follower.nickname} stopped following #{followed.ap_id}
+ #{inserted_at}
+ #{updated_at}
+
+ http://activitystrea.ms/schema/1.0/person
+ #{followed.ap_id}
+ #{followed.ap_id}
+
+
+
+ """
+
+ assert clean(res) == clean(expected)
+ end
+
test "an unknown activity" do
tuple = ActivityRepresenter.to_simple_form(%Activity{}, nil)
assert is_nil(tuple)