1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980 |
- # frozen_string_literal: true
- require 'rails_helper'
- RSpec.describe ActivityPub::Activity::Delete do
- let(:sender) { Fabricate(:account, domain: 'example.com') }
- let(:status) { Fabricate(:status, account: sender, uri: 'foobar') }
- let(:json) do
- {
- '@context': 'https://www.w3.org/ns/activitystreams',
- id: 'foo',
- type: 'Delete',
- actor: ActivityPub::TagManager.instance.uri_for(sender),
- object: ActivityPub::TagManager.instance.uri_for(status),
- signature: 'foo',
- }.with_indifferent_access
- end
- describe '#perform' do
- subject { described_class.new(json, sender) }
- before do
- subject.perform
- end
- it 'deletes sender\'s status' do
- expect(Status.find_by(id: status.id)).to be_nil
- end
- end
- context 'when the status has been reblogged' do
- describe '#perform' do
- subject { described_class.new(json, sender) }
- let!(:reblogger) { Fabricate(:account) }
- let!(:follower) { Fabricate(:account, username: 'follower', protocol: :activitypub, domain: 'example.com', inbox_url: 'http://example.com/inbox') }
- let!(:reblog) { Fabricate(:status, account: reblogger, reblog: status) }
- before do
- stub_request(:post, 'http://example.com/inbox').to_return(status: 200)
- follower.follow!(reblogger)
- subject.perform
- end
- it 'deletes sender\'s status' do
- expect(Status.find_by(id: status.id)).to be_nil
- end
- it 'sends delete activity to followers of rebloggers', :inline_jobs do
- expect(a_request(:post, 'http://example.com/inbox')).to have_been_made.once
- end
- it 'deletes the reblog' do
- expect { reblog.reload }.to raise_error(ActiveRecord::RecordNotFound)
- end
- end
- end
- context 'when the status has been reported' do
- describe '#perform' do
- subject { described_class.new(json, sender) }
- let!(:reporter) { Fabricate(:account) }
- before do
- reporter.reports.create!(target_account: status.account, status_ids: [status.id], forwarded: false)
- subject.perform
- end
- it 'marks the status as deleted' do
- expect(Status.find_by(id: status.id)).to be_nil
- end
- it 'actually keeps a copy for inspection' do
- expect(Status.with_discarded.find_by(id: status.id)).to_not be_nil
- end
- end
- end
- end
|