summaryrefslogtreecommitdiff
path: root/test/web/mastodon_api/status_view_test.exs
diff options
context:
space:
mode:
authorlambadalambda <gitgud@rogerbraun.net>2017-09-11 15:16:49 -0400
committerlambadalambda <gitgud@rogerbraun.net>2017-09-11 15:16:49 -0400
commit2b21c05105d550d09d85807246be696a1aed4b32 (patch)
treed389818eff185ca584449f2fb47ad7c1254fa3af /test/web/mastodon_api/status_view_test.exs
parent95aa6a3c651fed9810889d3446f2a1d710efb55e (diff)
parentf0d41a3abf3e584c90c96644f73d533ea0680237 (diff)
downloadpleroma-2b21c05105d550d09d85807246be696a1aed4b32.tar.gz
pleroma-2b21c05105d550d09d85807246be696a1aed4b32.zip
Merge branch 'oauth2' into 'develop'
Mastodon API See merge request !27
Diffstat (limited to 'test/web/mastodon_api/status_view_test.exs')
-rw-r--r--test/web/mastodon_api/status_view_test.exs77
1 files changed, 77 insertions, 0 deletions
diff --git a/test/web/mastodon_api/status_view_test.exs b/test/web/mastodon_api/status_view_test.exs
new file mode 100644
index 000000000..a12fc8244
--- /dev/null
+++ b/test/web/mastodon_api/status_view_test.exs
@@ -0,0 +1,77 @@
+defmodule Pleroma.Web.MastodonAPI.StatusViewTest do
+ use Pleroma.DataCase
+
+ alias Pleroma.Web.MastodonAPI.{StatusView, AccountView}
+ alias Pleroma.{User, Object}
+ alias Pleroma.Web.OStatus
+ import Pleroma.Factory
+
+ test "a note activity" do
+ note = insert(:note_activity)
+ user = User.get_cached_by_ap_id(note.data["actor"])
+
+ status = StatusView.render("status.json", %{activity: note})
+
+ expected = %{
+ id: note.id,
+ uri: note.data["object"]["id"],
+ url: note.data["object"]["external_id"],
+ account: AccountView.render("account.json", %{user: user}),
+ in_reply_to_id: nil,
+ in_reply_to_account_id: nil,
+ reblog: nil,
+ content: HtmlSanitizeEx.basic_html(note.data["object"]["content"]),
+ created_at: note.data["object"]["published"],
+ reblogs_count: 0,
+ favourites_count: 0,
+ reblogged: false,
+ favourited: false,
+ muted: false,
+ sensitive: false,
+ spoiler_text: "",
+ visibility: "public",
+ media_attachments: [],
+ mentions: [],
+ tags: [],
+ application: nil,
+ language: nil
+ }
+
+ assert status == expected
+ end
+
+ test "contains mentions" do
+ incoming = File.read!("test/fixtures/incoming_reply_mastodon.xml")
+ user = insert(:user, %{ap_id: "https://pleroma.soykaf.com/users/lain"})
+
+ {:ok, [activity]} = OStatus.handle_incoming(incoming)
+
+ status = StatusView.render("status.json", %{activity: activity})
+
+ assert status.mentions == [AccountView.render("mention.json", %{user: user})]
+ end
+
+ test "attachments" do
+ incoming = File.read!("test/fixtures/incoming_reply_mastodon.xml")
+ object = %{
+ "type" => "Image",
+ "url" => [
+ %{
+ "mediaType" => "image/png",
+ "href" => "someurl"
+ }
+ ],
+ "uuid" => 6
+ }
+
+ expected = %{
+ id: 6,
+ type: "image",
+ url: "someurl",
+ remote_url: "someurl",
+ preview_url: "someurl"
+ }
+
+ assert expected == StatusView.render("attachment.json", %{attachment: object})
+ end
+end