Add extended domain block tests

This commit is contained in:
KMY 2023-09-04 12:07:29 +09:00
parent 43144661ea
commit 7a0bf2e948
6 changed files with 231 additions and 15 deletions

View file

@ -29,10 +29,11 @@ RSpec.describe ActivityPub::Activity::Create do
subject { described_class.new(json, sender) }
let(:sender_software) { 'mastodon' }
let(:custom_before) { false }
before do
Fabricate(:instance_info, domain: 'example.com', software: sender_software)
subject.perform
subject.perform unless custom_before
end
context 'when object has been edited' do
@ -648,6 +649,80 @@ RSpec.describe ActivityPub::Activity::Create do
end
end
context 'with mentions domain block reject_reply' do
before do
Fabricate(:domain_block, domain: 'example.com', severity: :noop, reject_reply: true)
subject.perform
end
let(:custom_before) { true }
let(:recipient) { Fabricate(:account) }
let(:object_json) do
{
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
type: 'Note',
content: 'Lorem ipsum',
tag: [
{
type: 'Mention',
href: ActivityPub::TagManager.instance.uri_for(recipient),
},
],
}
end
it 'creates status' do
status = sender.statuses.first
expect(status).to be_nil
end
end
context 'with mentions domain block reject_reply_exclude_followers' do
before do
Fabricate(:domain_block, domain: 'example.com', severity: :noop, reject_reply_exclude_followers: true)
recipient.follow!(sender) if follow
subject.perform
end
let(:custom_before) { true }
let(:follow) { false }
let(:recipient) { Fabricate(:account) }
let(:object_json) do
{
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
type: 'Note',
content: 'Lorem ipsum',
tag: [
{
type: 'Mention',
href: ActivityPub::TagManager.instance.uri_for(recipient),
},
],
}
end
context 'when follower' do
let(:follow) { true }
it 'creates status' do
status = sender.statuses.first
expect(status).to_not be_nil
end
end
context 'when not follower' do
it 'creates status' do
status = sender.statuses.first
expect(status).to be_nil
end
end
end
context 'with media attachments' do
let(:object_json) do
{