Add tests for mismatched context in replies
This commit is contained in:
parent
5a4e3aa715
commit
2d77976305
|
@ -0,0 +1,35 @@
|
||||||
|
{
|
||||||
|
"@context": [
|
||||||
|
"https://www.w3.org/ns/activitystreams",
|
||||||
|
"https://gleasonator.com/schemas/litepub-0.1.jsonld",
|
||||||
|
{
|
||||||
|
"@language": "und"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"actor": "https://gleasonator.com/users/macgirvin",
|
||||||
|
"attachment": [],
|
||||||
|
"attributedTo": "https://gleasonator.com/users/macgirvin",
|
||||||
|
"cc": [
|
||||||
|
"https://gleasonator.com/users/macgirvin/followers"
|
||||||
|
],
|
||||||
|
"content": "<span class=\"h-card\"><a class=\"u-url mention\" data-user=\"9v5bmRalQvjOy0ECcC\" href=\"https://gleasonator.com/users/alex\" rel=\"ugc\">@<span>alex</span></a></span> Any idea why my posts are failing? I sent an Accept/Follow from <a href=\"http://macgirvin.com\" rel=\"ugc\">macgirvin.com</a> at 2022-02-02T04:06:01Z and it vanished into space. As do all my comments to you. <br><br>2022-02-02T04:06:01Z:LOG_INFO:d5c4aa7f6a:Queue.php:435:deliver: deliver: queue post returned 200 from <a href=\"https://gleasonator.com/users/macgirvin/inbox\" rel=\"ugc\">https://gleasonator.com/users/macgirvin/inbox</a><br><br>It's OK if I'm blocked, but if that's the case, I shouldn't be able to send a follow to that address should I?",
|
||||||
|
"context": "https://gleasonator.com/contexts/b7f01f94-bc92-4d89-a085-0ffc211b0e42",
|
||||||
|
"conversation": "https://gleasonator.com/contexts/b7f01f94-bc92-4d89-a085-0ffc211b0e42",
|
||||||
|
"id": "https://gleasonator.com/objects/102eb097-a18b-4cd5-abfc-f952efcb70bb",
|
||||||
|
"published": "2022-02-02T04:14:10.965833Z",
|
||||||
|
"sensitive": false,
|
||||||
|
"source": "@alex Any idea why my posts are failing? I sent an Accept/Follow from macgirvin.com at 2022-02-02T04:06:01Z and it vanished into space. As do all my comments to you. \n\n2022-02-02T04:06:01Z:LOG_INFO:d5c4aa7f6a:Queue.php:435:deliver: deliver: queue post returned 200 from https://gleasonator.com/users/macgirvin/inbox\n\nIt's OK if I'm blocked, but if that's the case, I shouldn't be able to send a follow to that address should I?",
|
||||||
|
"summary": "",
|
||||||
|
"tag": [
|
||||||
|
{
|
||||||
|
"href": "https://gleasonator.com/users/alex",
|
||||||
|
"name": "@alex",
|
||||||
|
"type": "Mention"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"to": [
|
||||||
|
"https://www.w3.org/ns/activitystreams#Public",
|
||||||
|
"https://gleasonator.com/users/alex"
|
||||||
|
],
|
||||||
|
"type": "Note"
|
||||||
|
}
|
|
@ -0,0 +1,41 @@
|
||||||
|
{
|
||||||
|
"@context": [
|
||||||
|
"https://www.w3.org/ns/activitystreams",
|
||||||
|
"https://gleasonator.com/schemas/litepub-0.1.jsonld",
|
||||||
|
{
|
||||||
|
"@language": "und"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"alsoKnownAs": [],
|
||||||
|
"attachment": [],
|
||||||
|
"capabilities": {
|
||||||
|
"acceptsChatMessages": true
|
||||||
|
},
|
||||||
|
"discoverable": false,
|
||||||
|
"endpoints": {
|
||||||
|
"oauthAuthorizationEndpoint": "https://gleasonator.com/oauth/authorize",
|
||||||
|
"oauthRegistrationEndpoint": "https://gleasonator.com/api/v1/apps",
|
||||||
|
"oauthTokenEndpoint": "https://gleasonator.com/oauth/token",
|
||||||
|
"sharedInbox": "https://gleasonator.com/inbox",
|
||||||
|
"uploadMedia": "https://gleasonator.com/api/ap/upload_media"
|
||||||
|
},
|
||||||
|
"featured": "https://gleasonator.com/users/macgirvin/collections/featured",
|
||||||
|
"followers": "https://gleasonator.com/users/macgirvin/followers",
|
||||||
|
"following": "https://gleasonator.com/users/macgirvin/following",
|
||||||
|
"id": "https://gleasonator.com/users/macgirvin",
|
||||||
|
"inbox": "https://gleasonator.com/users/macgirvin/inbox",
|
||||||
|
"manuallyApprovesFollowers": false,
|
||||||
|
"name": "macgirvin",
|
||||||
|
"outbox": "https://gleasonator.com/users/macgirvin/outbox",
|
||||||
|
"preferredUsername": "macgirvin",
|
||||||
|
"publicKey": {
|
||||||
|
"id": "https://gleasonator.com/users/macgirvin#main-key",
|
||||||
|
"owner": "https://gleasonator.com/users/macgirvin",
|
||||||
|
"publicKeyPem": "-----BEGIN PUBLIC KEY-----\nMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA0AUMgsQu87tLwoJjZfZu\nsj7NV0qt/THdK8aw4Ha2GZfNkwrep99AZ8gmCI+rr+N5vyETAARzG5/Qzr5bNTUx\nsc1fxFemhhi6sxzAv4qZ5AgvWQ4YPFWizSp5ZY1jpPHLOeF2IftMf8CwVI82PtD0\n7m7T6iUYA4vfvMp9LxVrzQA+CAtpsQxAejTGCt37yM9T2mEWqfmJQQHRIQ4brKBL\nI82sNbzk1cbTwCfH7vRNS/l1ND+vaUGGkDKtpRl56BLmt4picYL0avc+8oO7ebpc\n/zUoS8OOi+mpEzjv7TBrSirYEIGvIh3TKHWSPrpHpQTqj9xBQBy+AxXTWahQEO2M\ndQIDAQAB\n-----END PUBLIC KEY-----\n\n"
|
||||||
|
},
|
||||||
|
"summary": "",
|
||||||
|
"tag": [],
|
||||||
|
"type": "Person",
|
||||||
|
"url": "https://gleasonator.com/users/macgirvin",
|
||||||
|
"vcard:bday": null
|
||||||
|
}
|
|
@ -7,6 +7,7 @@ defmodule Pleroma.Web.ActivityPub.ObjectValidators.CreateGenericValidatorTest do
|
||||||
|
|
||||||
alias Pleroma.Web.ActivityPub.ObjectValidator
|
alias Pleroma.Web.ActivityPub.ObjectValidator
|
||||||
alias Pleroma.Web.ActivityPub.ObjectValidators.CreateGenericValidator
|
alias Pleroma.Web.ActivityPub.ObjectValidators.CreateGenericValidator
|
||||||
|
alias Pleroma.Web.ActivityPub.Utils
|
||||||
|
|
||||||
import Pleroma.Factory
|
import Pleroma.Factory
|
||||||
|
|
||||||
|
@ -24,4 +25,35 @@ test "a Create/Note from Roadhouse validates" do
|
||||||
|
|
||||||
%{valid?: true} = CreateGenericValidator.cast_and_validate(note_activity, meta)
|
%{valid?: true} = CreateGenericValidator.cast_and_validate(note_activity, meta)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
test "a Create/Note with mismatched context is invalid" do
|
||||||
|
user = insert(:user)
|
||||||
|
|
||||||
|
note = %{
|
||||||
|
"id" => Utils.generate_object_id(),
|
||||||
|
"type" => "Note",
|
||||||
|
"actor" => user.ap_id,
|
||||||
|
"to" => [user.follower_address],
|
||||||
|
"cc" => [],
|
||||||
|
"content" => "Hello world",
|
||||||
|
"context" => Utils.generate_context_id()
|
||||||
|
}
|
||||||
|
|
||||||
|
note_activity = %{
|
||||||
|
"id" => Utils.generate_activity_id(),
|
||||||
|
"type" => "Create",
|
||||||
|
"actor" => note["actor"],
|
||||||
|
"to" => note["to"],
|
||||||
|
"cc" => note["cc"],
|
||||||
|
"object" => note,
|
||||||
|
"published" => DateTime.utc_now() |> DateTime.to_iso8601(),
|
||||||
|
"context" => Utils.generate_context_id()
|
||||||
|
}
|
||||||
|
|
||||||
|
# Build metadata
|
||||||
|
{:ok, object_data} = ObjectValidator.cast_and_apply(note_activity["object"])
|
||||||
|
meta = [object_data: ObjectValidator.stringify_keys(object_data)]
|
||||||
|
|
||||||
|
%{valid?: false} = CreateGenericValidator.cast_and_validate(note_activity, meta)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -107,6 +107,17 @@ test "it accepts Move activities" do
|
||||||
assert activity.data["target"] == new_user.ap_id
|
assert activity.data["target"] == new_user.ap_id
|
||||||
assert activity.data["type"] == "Move"
|
assert activity.data["type"] == "Move"
|
||||||
end
|
end
|
||||||
|
|
||||||
|
test "a reply with mismatched context is rejected" do
|
||||||
|
insert(:user, ap_id: "https://macgirvin.com/channel/mike")
|
||||||
|
|
||||||
|
note_activity =
|
||||||
|
"test/fixtures/roadhouse-create-activity.json"
|
||||||
|
|> File.read!()
|
||||||
|
|> Jason.decode!()
|
||||||
|
|
||||||
|
assert {:error, _} = Transmogrifier.handle_incoming(note_activity)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
describe "prepare outgoing" do
|
describe "prepare outgoing" do
|
||||||
|
|
|
@ -1311,6 +1311,36 @@ def get("https://patch.cx/objects/a399c28e-c821-4820-bc3e-4afeb044c16f", _, _, _
|
||||||
}}
|
}}
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def get("https://gleasonator.com/objects/102eb097-a18b-4cd5-abfc-f952efcb70bb", _, _, _) do
|
||||||
|
{:ok,
|
||||||
|
%Tesla.Env{
|
||||||
|
status: 200,
|
||||||
|
body: File.read!("test/fixtures/tesla_mock/gleasonator-AG3RzWfwEKKrY63qj2.json"),
|
||||||
|
headers: activitypub_object_headers()
|
||||||
|
}}
|
||||||
|
end
|
||||||
|
|
||||||
|
def get("https://gleasonator.com/users/macgirvin", _, _, _) do
|
||||||
|
{:ok,
|
||||||
|
%Tesla.Env{
|
||||||
|
status: 200,
|
||||||
|
body: File.read!("test/fixtures/tesla_mock/macgirvin@gleasonator.com.json"),
|
||||||
|
headers: activitypub_object_headers()
|
||||||
|
}}
|
||||||
|
end
|
||||||
|
|
||||||
|
def get("https://gleasonator.com/users/macgirvin/collections/featured", _, _, _) do
|
||||||
|
{:ok,
|
||||||
|
%Tesla.Env{
|
||||||
|
status: 200,
|
||||||
|
body:
|
||||||
|
File.read!("test/fixtures/users_mock/masto_featured.json")
|
||||||
|
|> String.replace("{{domain}}", "gleasonator.com")
|
||||||
|
|> String.replace("{{nickname}}", "macgirvin"),
|
||||||
|
headers: activitypub_object_headers()
|
||||||
|
}}
|
||||||
|
end
|
||||||
|
|
||||||
def get(url, query, body, headers) do
|
def get(url, query, body, headers) do
|
||||||
{:error,
|
{:error,
|
||||||
"Mock response not implemented for GET #{inspect(url)}, #{query}, #{inspect(body)}, #{inspect(headers)}"}
|
"Mock response not implemented for GET #{inspect(url)}, #{query}, #{inspect(body)}, #{inspect(headers)}"}
|
||||||
|
|
Loading…
Reference in New Issue