1 # Pleroma: A lightweight social networking server
2 # Copyright © 2017-2021 Pleroma Authors <https://pleroma.social/>
3 # SPDX-License-Identifier: AGPL-3.0-only
5 defmodule Pleroma.Web.ActivityPub.ObjectValidators.ArticleNotePageValidatorTest do
6 use Pleroma.DataCase, async: true
8 alias Pleroma.Web.ActivityPub.ObjectValidator
9 alias Pleroma.Web.ActivityPub.ObjectValidators.ArticleNotePageValidator
10 alias Pleroma.Web.ActivityPub.Utils
12 import Pleroma.Factory
15 Tesla.Mock.mock_global(fn env -> apply(HttpRequestMock, :request, [env]) end)
25 "id" => Utils.generate_activity_id(),
27 "actor" => user.ap_id,
28 "to" => [user.follower_address],
30 "content" => "Hellow this is content.",
35 %{user: user, note: note}
38 test "a basic note validates", %{note: note} do
39 %{valid?: true} = ArticleNotePageValidator.cast_and_validate(note)
42 test "a note from factory validates" do
44 %{valid?: true} = ArticleNotePageValidator.cast_and_validate(note.data)
47 test "a note with a remote replies collection should validate", _ do
48 insert(:user, %{ap_id: "https://bookwyrm.com/user/TestUser"})
49 collection = File.read!("test/fixtures/bookwyrm-replies-collection.json")
53 url: "https://bookwyrm.com/user/TestUser/review/17/replies?page=1"
58 headers: HttpRequestMock.activitypub_object_headers()
62 note = Jason.decode!(File.read!("test/fixtures/bookwyrm-article.json"))
64 %{valid?: true, changes: %{replies: ["https://bookwyrm.com/user/TestUser/status/18"]}} =
65 ArticleNotePageValidator.cast_and_validate(note)
68 test "a note with an attachment should work", _ do
69 insert(:user, %{ap_id: "https://owncast.localhost.localdomain/federation/user/streamer"})
72 "test/fixtures/owncast-note-with-attachment.json"
76 %{valid?: true} = ArticleNotePageValidator.cast_and_validate(note)
79 test "a misskey MFM status with a content field should work and be linked", _ do
81 insert(:user, %{nickname: "akkoma_user", ap_id: "http://localhost:4001/users/akkoma_user"})
85 nickname: "remote_user",
86 ap_id: "http://misskey.local.live/users/remote_user"
89 full_tag_remote_user =
91 nickname: "full_tag_remote_user",
92 ap_id: "http://misskey.local.live/users/full_tag_remote_user"
95 insert(:user, %{ap_id: "https://misskey.local.live/users/92hzkskwgy"})
98 "test/fixtures/misskey/mfm_x_format.json"
107 "mediaType" => "text/x.misskeymarkdown"
110 } = ArticleNotePageValidator.cast_and_validate(note)
113 "<span class=\"h-card\"><a class=\"u-url mention\" data-user=\"#{local_user.id}\" href=\"#{local_user.ap_id}\" rel=\"ugc\">@<span>akkoma_user</span></a></span>"
116 "<span class=\"h-card\"><a class=\"u-url mention\" data-user=\"#{remote_user.id}\" href=\"#{remote_user.ap_id}\" rel=\"ugc\">@<span>remote_user</span></a></span>"
119 "<span class=\"h-card\"><a class=\"u-url mention\" data-user=\"#{full_tag_remote_user.id}\" href=\"#{full_tag_remote_user.ap_id}\" rel=\"ugc\">@<span>full_tag_remote_user</span></a></span>"
121 assert content =~ "@oops_not_a_mention"
124 "<span class=\"mfm _mfm_jelly_\" style=\"display: inline-block; animation: 1s linear 0s infinite normal both running mfm-rubberBand;\">mfm goes here</span> </p>aaa"
127 test "a misskey MFM status with a _misskey_content field should work and be linked", _ do
129 insert(:user, %{nickname: "akkoma_user", ap_id: "http://localhost:4001/users/akkoma_user"})
131 insert(:user, %{ap_id: "https://misskey.local.live/users/92hzkskwgy"})
134 "test/fixtures/misskey/mfm_underscore_format.json"
138 changes = ArticleNotePageValidator.cast_and_validate(note)
145 "mediaType" => "text/x.misskeymarkdown",
146 "content" => "@akkoma_user linkifylink #dancedance $[jelly mfm goes here] \n\n## aaa"
152 "<span class=\"h-card\"><a class=\"u-url mention\" data-user=\"#{local_user.id}\" href=\"#{local_user.ap_id}\" rel=\"ugc\">@<span>akkoma_user</span></a></span>"
156 test "a Note without replies/first/items validates" do
157 insert(:user, ap_id: "https://mastodon.social/users/emelie")
160 "test/fixtures/tesla_mock/status.emelie.json"
163 |> pop_in(["replies", "first", "items"])
166 %{valid?: true} = ArticleNotePageValidator.cast_and_validate(note)
169 describe "Note with history" do
172 {:ok, activity} = Pleroma.Web.CommonAPI.post(user, %{status: "mew mew :dinosaur:"})
173 {:ok, edit} = Pleroma.Web.CommonAPI.update(user, activity, %{status: "edited :blank:"})
175 {:ok, %{"object" => external_rep}} =
176 Pleroma.Web.ActivityPub.Transmogrifier.prepare_outgoing(edit.data)
178 %{external_rep: external_rep}
181 test "edited note", %{external_rep: external_rep} do
182 assert %{"formerRepresentations" => %{"orderedItems" => [%{"tag" => [_]}]}} = external_rep
184 {:ok, validate_res, []} = ObjectValidator.validate(external_rep, [])
186 assert %{"formerRepresentations" => %{"orderedItems" => [%{"emoji" => %{"dinosaur" => _}}]}} =
190 test "edited note, badly-formed formerRepresentations", %{external_rep: external_rep} do
191 external_rep = Map.put(external_rep, "formerRepresentations", %{})
193 assert {:error, _} = ObjectValidator.validate(external_rep, [])
196 test "edited note, badly-formed history item", %{external_rep: external_rep} do
198 Enum.at(external_rep["formerRepresentations"]["orderedItems"], 0)
199 |> Map.put("type", "Foo")
204 ["formerRepresentations", "orderedItems"],
208 assert {:error, _} = ObjectValidator.validate(external_rep, [])