Handle local/remote collection items differently when deleting (#38383)

This commit is contained in:
David Roetzel
2026-03-25 11:57:34 +01:00
committed by GitHub
parent 74123950be
commit d9db4779cf
2 changed files with 26 additions and 10 deletions

View File

@@ -13,17 +13,30 @@ RSpec.describe DeleteCollectionItemService do
expect { subject.call(collection_item) }.to change(collection.collection_items, :count).by(-1)
end
it 'federates a `Remove` activity', feature: :collections_federation do
subject.call(collection_item)
context 'when the collection is local' do
it 'federates a `Remove` activity', feature: :collections_federation do
subject.call(collection_item)
expect(ActivityPub::AccountRawDistributionWorker).to have_enqueued_sidekiq_job
expect(ActivityPub::AccountRawDistributionWorker).to have_enqueued_sidekiq_job
end
context 'when `revoke` is set to true' do
it 'revokes the collection item' do
subject.call(collection_item, revoke: true)
expect(collection_item.reload).to be_revoked
end
end
end
context 'when `revoke` is set to true' do
it 'revokes the collection item' do
subject.call(collection_item, revoke: true)
context 'when the collection is remote' do
let(:collection) { Fabricate(:remote_collection) }
let!(:collection_item) { Fabricate(:collection_item, collection:, state: :accepted) }
expect(collection_item.reload).to be_revoked
it 'destroys the collection withouth federating anything', feature: :collections_federation do
expect { subject.call(collection_item, revoke: true) }.to change(collection.collection_items, :count).by(-1)
expect(ActivityPub::AccountRawDistributionWorker).to_not have_enqueued_sidekiq_job
end
end
end