120 lines
3.6 KiB
Elixir
120 lines
3.6 KiB
Elixir
# Pleroma: A lightweight social networking server
|
|
# Copyright © 2017-2022 Pleroma Authors <https://pleroma.social/>
|
|
# SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
defmodule Pleroma.Web.ActivityPub.ObjectValidators.ArticleNotePageValidatorTest do
|
|
use Pleroma.DataCase, async: true
|
|
|
|
alias Pleroma.Web.ActivityPub.ObjectValidator
|
|
alias Pleroma.Web.ActivityPub.ObjectValidators.ArticleNotePageValidator
|
|
alias Pleroma.Web.ActivityPub.Utils
|
|
|
|
import Pleroma.Factory
|
|
|
|
describe "Notes" do
|
|
setup do
|
|
user = insert(:user)
|
|
|
|
note = %{
|
|
"id" => Utils.generate_activity_id(),
|
|
"type" => "Note",
|
|
"actor" => user.ap_id,
|
|
"to" => [user.follower_address],
|
|
"cc" => [],
|
|
"content" => "Hellow this is content.",
|
|
"context" => "xxx",
|
|
"summary" => "a post"
|
|
}
|
|
|
|
%{user: user, note: note}
|
|
end
|
|
|
|
test "a basic note validates", %{note: note} do
|
|
%{valid?: true} = ArticleNotePageValidator.cast_and_validate(note)
|
|
end
|
|
|
|
test "a note from factory validates" do
|
|
note = insert(:note)
|
|
%{valid?: true} = ArticleNotePageValidator.cast_and_validate(note.data)
|
|
end
|
|
end
|
|
|
|
describe "Note with history" do
|
|
setup do
|
|
user = insert(:user)
|
|
{:ok, activity} = Pleroma.Web.CommonAPI.post(user, %{status: "mew mew :dinosaur:"})
|
|
{:ok, edit} = Pleroma.Web.CommonAPI.update(user, activity, %{status: "edited :blank:"})
|
|
|
|
{:ok, %{"object" => external_rep}} =
|
|
Pleroma.Web.ActivityPub.Transmogrifier.prepare_outgoing(edit.data)
|
|
|
|
%{external_rep: external_rep}
|
|
end
|
|
|
|
test "edited note", %{external_rep: external_rep} do
|
|
assert %{"formerRepresentations" => %{"orderedItems" => [%{"tag" => [_]}]}} = external_rep
|
|
|
|
{:ok, validate_res, []} = ObjectValidator.validate(external_rep, [])
|
|
|
|
assert %{"formerRepresentations" => %{"orderedItems" => [%{"emoji" => %{"dinosaur" => _}}]}} =
|
|
validate_res
|
|
end
|
|
|
|
test "edited note, badly-formed formerRepresentations", %{external_rep: external_rep} do
|
|
external_rep = Map.put(external_rep, "formerRepresentations", %{})
|
|
|
|
assert {:error, _} = ObjectValidator.validate(external_rep, [])
|
|
end
|
|
|
|
test "edited note, badly-formed history item", %{external_rep: external_rep} do
|
|
history_item =
|
|
Enum.at(external_rep["formerRepresentations"]["orderedItems"], 0)
|
|
|> Map.put("type", "Foo")
|
|
|
|
external_rep =
|
|
put_in(
|
|
external_rep,
|
|
["formerRepresentations", "orderedItems"],
|
|
[history_item]
|
|
)
|
|
|
|
assert {:error, _} = ObjectValidator.validate(external_rep, [])
|
|
end
|
|
end
|
|
|
|
test "a Note from Roadhouse validates" do
|
|
insert(:user, ap_id: "https://macgirvin.com/channel/mike")
|
|
|
|
%{"object" => note} =
|
|
"test/fixtures/roadhouse-create-activity.json"
|
|
|> File.read!()
|
|
|> Jason.decode!()
|
|
|
|
%{valid?: true} = ArticleNotePageValidator.cast_and_validate(note)
|
|
end
|
|
|
|
test "a note with an attachment should work", _ do
|
|
insert(:user, %{ap_id: "https://owncast.localhost.localdomain/federation/user/streamer"})
|
|
|
|
note =
|
|
"test/fixtures/owncast-note-with-attachment.json"
|
|
|> File.read!()
|
|
|> Jason.decode!()
|
|
|
|
%{valid?: true} = ArticleNotePageValidator.cast_and_validate(note)
|
|
end
|
|
|
|
test "a Note without replies/first/items validates" do
|
|
insert(:user, ap_id: "https://mastodon.social/users/emelie")
|
|
|
|
note =
|
|
"test/fixtures/tesla_mock/status.emelie.json"
|
|
|> File.read!()
|
|
|> Jason.decode!()
|
|
|> pop_in(["replies", "first", "items"])
|
|
|> elem(1)
|
|
|
|
%{valid?: true} = ArticleNotePageValidator.cast_and_validate(note)
|
|
end
|
|
end
|