12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394 |
- # frozen_string_literal: true
- require 'rails_helper'
- RSpec.describe ReblogService, type: :service do
- let(:alice) { Fabricate(:account, username: 'alice') }
- context 'when creates a reblog with appropriate visibility' do
- subject { described_class.new }
- let(:visibility) { :public }
- let(:reblog_visibility) { :public }
- let(:status) { Fabricate(:status, account: alice, visibility: visibility) }
- before do
- subject.call(alice, status, visibility: reblog_visibility)
- end
- describe 'boosting privately' do
- let(:reblog_visibility) { :private }
- it 'reblogs privately' do
- expect(status.reblogs.first.visibility).to eq 'private'
- end
- end
- describe 'public reblogs of private toots should remain private' do
- let(:visibility) { :private }
- let(:reblog_visibility) { :public }
- it 'reblogs privately' do
- expect(status.reblogs.first.visibility).to eq 'private'
- end
- end
- end
- context 'when the reblogged status is discarded in the meantime' do
- let(:status) { Fabricate(:status, account: alice, visibility: :public, text: 'discard-status-text') }
- # Add a callback to discard the status being reblogged after the
- # validations pass but before the database commit is executed.
- before do
- Status.class_eval do
- before_save :discard_status
- def discard_status
- Status
- .where(id: reblog_of_id)
- .where(text: 'discard-status-text')
- .update_all(deleted_at: Time.now.utc) # rubocop:disable Rails/SkipsModelValidations
- end
- end
- end
- # Remove race condition simulating `discard_status` callback.
- after do
- Status._save_callbacks.delete(:discard_status)
- end
- it 'raises an exception' do
- expect { subject.call(alice, status) }.to raise_error ActiveRecord::ActiveRecordError
- end
- end
- context 'with ActivityPub' do
- subject { described_class.new }
- let(:bob) { Fabricate(:account, username: 'bob', protocol: :activitypub, domain: 'example.com', inbox_url: 'http://example.com/inbox') }
- let(:status) { Fabricate(:status, account: bob) }
- before do
- stub_request(:post, bob.inbox_url)
- allow(ActivityPub::DistributionWorker).to receive(:perform_async)
- subject.call(alice, status)
- end
- it 'creates a reblog' do
- expect(status.reblogs.count).to eq 1
- end
- describe 'after_create_commit :store_uri' do
- it 'keeps consistent reblog count' do
- expect(status.reblogs.count).to eq 1
- end
- end
- it 'distributes to followers' do
- expect(ActivityPub::DistributionWorker).to have_received(:perform_async)
- end
- it 'sends an announce activity to the author' do
- expect(a_request(:post, bob.inbox_url)).to have_been_made.once
- end
- end
- end
|