mirror of
https://github.com/glitch-soc/mastodon.git
synced 2026-03-29 03:00:33 +02:00
Handle local/remote collection items differently when deleting (#38383)
This commit is contained in:
@@ -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
|
||||
|
||||
Reference in New Issue
Block a user