2023-02-21 16:55:31 -08:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2016-02-24 15:17:01 -08:00
|
|
|
require 'rails_helper'
|
|
|
|
|
2018-05-02 09:58:48 -07:00
|
|
|
RSpec.describe ReblogService, type: :service do
|
2016-02-28 12:22:56 -08:00
|
|
|
let(:alice) { Fabricate(:account, username: 'alice') }
|
|
|
|
|
2023-05-03 20:49:08 -07:00
|
|
|
context 'when creates a reblog with appropriate visibility' do
|
2023-06-06 04:58:33 -07:00
|
|
|
subject { described_class.new }
|
2023-02-19 20:24:14 -08:00
|
|
|
|
2019-03-17 06:54:09 -07:00
|
|
|
let(:visibility) { :public }
|
|
|
|
let(:reblog_visibility) { :public }
|
2019-05-17 15:28:51 -07:00
|
|
|
let(:status) { Fabricate(:status, account: alice, visibility: visibility) }
|
2019-03-17 06:54:09 -07:00
|
|
|
|
|
|
|
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
|
2019-05-17 15:28:51 -07:00
|
|
|
|
|
|
|
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
|
2019-03-17 06:54:09 -07:00
|
|
|
end
|
|
|
|
|
2022-03-09 15:11:49 -08:00
|
|
|
context 'when the reblogged status is discarded in the meantime' do
|
2023-04-14 05:42:10 -07:00
|
|
|
let(:status) { Fabricate(:status, account: alice, visibility: :public, text: 'discard-status-text') }
|
2022-03-09 15:11:49 -08:00
|
|
|
|
2023-04-14 05:42:10 -07:00
|
|
|
# Add a callback to discard the status being reblogged after the
|
|
|
|
# validations pass but before the database commit is executed.
|
2022-03-09 15:11:49 -08:00
|
|
|
before do
|
2023-04-14 05:42:10 -07:00
|
|
|
Status.class_eval do
|
|
|
|
before_save :discard_status
|
|
|
|
def discard_status
|
|
|
|
Status
|
|
|
|
.where(id: reblog_of_id)
|
|
|
|
.where(text: 'discard-status-text')
|
2024-01-15 05:46:47 -08:00
|
|
|
.update_all(deleted_at: Time.now.utc)
|
2023-04-14 05:42:10 -07:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# Remove race condition simulating `discard_status` callback.
|
|
|
|
after do
|
|
|
|
Status._save_callbacks.delete(:discard_status)
|
2022-03-09 15:11:49 -08:00
|
|
|
end
|
|
|
|
|
|
|
|
it 'raises an exception' do
|
|
|
|
expect { subject.call(alice, status) }.to raise_error ActiveRecord::ActiveRecordError
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2023-05-03 20:49:08 -07:00
|
|
|
context 'with ActivityPub' do
|
2023-06-06 04:58:33 -07:00
|
|
|
subject { described_class.new }
|
2023-02-19 20:24:14 -08:00
|
|
|
|
2017-08-12 15:44:41 -07:00
|
|
|
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
|
|
|
|
|
2017-10-12 17:52:09 -07:00
|
|
|
describe 'after_create_commit :store_uri' do
|
|
|
|
it 'keeps consistent reblog count' do
|
|
|
|
expect(status.reblogs.count).to eq 1
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2017-08-12 15:44:41 -07:00
|
|
|
it 'distributes to followers' do
|
|
|
|
expect(ActivityPub::DistributionWorker).to have_received(:perform_async)
|
|
|
|
end
|
2016-02-28 12:22:56 -08:00
|
|
|
end
|
2016-02-24 15:17:01 -08:00
|
|
|
end
|