2023-05-02 10:08:48 +00:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require 'rails_helper'
|
|
|
|
|
|
|
|
RSpec.describe BulkImportRowService do
|
|
|
|
subject { described_class.new }
|
|
|
|
|
|
|
|
let(:account) { Fabricate(:account) }
|
|
|
|
let(:import) { Fabricate(:bulk_import, account: account, type: import_type) }
|
|
|
|
let(:import_row) { Fabricate(:bulk_import_row, bulk_import: import, data: data) }
|
|
|
|
|
|
|
|
describe '#call' do
|
|
|
|
context 'when importing a follow' do
|
|
|
|
let(:import_type) { 'following' }
|
|
|
|
let(:target_account) { Fabricate(:account) }
|
|
|
|
let(:service_double) { instance_double(FollowService, call: nil) }
|
|
|
|
let(:data) do
|
|
|
|
{ 'acct' => target_account.acct }
|
|
|
|
end
|
|
|
|
|
|
|
|
before do
|
|
|
|
allow(FollowService).to receive(:new).and_return(service_double)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'calls FollowService with the expected arguments and returns true' do
|
|
|
|
expect(subject.call(import_row)).to be true
|
|
|
|
|
|
|
|
expect(service_double).to have_received(:call).with(account, target_account, { reblogs: nil, notify: nil, languages: nil })
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when importing a block' do
|
|
|
|
let(:import_type) { 'blocking' }
|
|
|
|
let(:target_account) { Fabricate(:account) }
|
|
|
|
let(:service_double) { instance_double(BlockService, call: nil) }
|
|
|
|
let(:data) do
|
|
|
|
{ 'acct' => target_account.acct }
|
|
|
|
end
|
|
|
|
|
|
|
|
before do
|
|
|
|
allow(BlockService).to receive(:new).and_return(service_double)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'calls BlockService with the expected arguments and returns true' do
|
|
|
|
expect(subject.call(import_row)).to be true
|
|
|
|
|
|
|
|
expect(service_double).to have_received(:call).with(account, target_account)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when importing a mute' do
|
|
|
|
let(:import_type) { 'muting' }
|
|
|
|
let(:target_account) { Fabricate(:account) }
|
|
|
|
let(:service_double) { instance_double(MuteService, call: nil) }
|
|
|
|
let(:data) do
|
|
|
|
{ 'acct' => target_account.acct }
|
|
|
|
end
|
|
|
|
|
|
|
|
before do
|
|
|
|
allow(MuteService).to receive(:new).and_return(service_double)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'calls MuteService with the expected arguments and returns true' do
|
|
|
|
expect(subject.call(import_row)).to be true
|
|
|
|
|
|
|
|
expect(service_double).to have_received(:call).with(account, target_account, { notifications: nil })
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when importing a bookmark' do
|
|
|
|
let(:import_type) { 'bookmarks' }
|
|
|
|
let(:data) do
|
|
|
|
{ 'uri' => ActivityPub::TagManager.instance.uri_for(target_status) }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when the status is public' do
|
|
|
|
let(:target_status) { Fabricate(:status) }
|
|
|
|
|
|
|
|
it 'bookmarks the status and returns true' do
|
|
|
|
expect(subject.call(import_row)).to be true
|
|
|
|
expect(account.bookmarked?(target_status)).to be true
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when the status is not accessible to the user' do
|
|
|
|
let(:target_status) { Fabricate(:status, visibility: :direct) }
|
|
|
|
|
|
|
|
it 'does not bookmark the status and returns false' do
|
|
|
|
expect(subject.call(import_row)).to be false
|
|
|
|
expect(account.bookmarked?(target_status)).to be false
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2023-06-01 12:47:31 +00:00
|
|
|
|
|
|
|
context 'when importing a list row' do
|
|
|
|
let(:import_type) { 'lists' }
|
|
|
|
let(:target_account) { Fabricate(:account) }
|
2024-04-17 08:23:25 +00:00
|
|
|
let(:list_name) { 'my list' }
|
2023-06-01 12:47:31 +00:00
|
|
|
let(:data) do
|
2024-04-17 08:23:25 +00:00
|
|
|
{ 'acct' => target_account.acct, 'list_name' => list_name }
|
2023-06-01 12:47:31 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
shared_examples 'common behavior' do
|
2024-04-17 08:23:25 +00:00
|
|
|
shared_examples 'row import success and list addition' do
|
|
|
|
it 'returns true and adds the target account to the list' do
|
|
|
|
result = nil
|
|
|
|
expect { result = subject.call(import_row) }
|
|
|
|
.to change { result }.from(nil).to(true)
|
|
|
|
.and add_target_account_to_list
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2023-06-01 12:47:31 +00:00
|
|
|
context 'when the target account is already followed' do
|
|
|
|
before do
|
|
|
|
account.follow!(target_account)
|
|
|
|
end
|
|
|
|
|
2024-04-17 08:23:25 +00:00
|
|
|
include_examples 'row import success and list addition'
|
2023-06-01 12:47:31 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
context 'when the user already requested to follow the target account' do
|
|
|
|
before do
|
|
|
|
account.request_follow!(target_account)
|
|
|
|
end
|
|
|
|
|
2024-04-17 08:23:25 +00:00
|
|
|
include_examples 'row import success and list addition'
|
2023-06-01 12:47:31 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
context 'when the target account is neither followed nor requested' do
|
2024-04-17 08:23:25 +00:00
|
|
|
include_examples 'row import success and list addition'
|
2023-06-01 12:47:31 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
context 'when the target account is the user themself' do
|
|
|
|
let(:target_account) { account }
|
|
|
|
|
2024-04-17 08:23:25 +00:00
|
|
|
include_examples 'row import success and list addition'
|
2023-06-01 12:47:31 +00:00
|
|
|
end
|
2024-03-15 09:31:25 +00:00
|
|
|
|
|
|
|
def add_target_account_to_list
|
|
|
|
change { target_account_on_list? }
|
|
|
|
.from(false)
|
|
|
|
.to(true)
|
|
|
|
end
|
|
|
|
|
|
|
|
def target_account_on_list?
|
|
|
|
ListAccount
|
|
|
|
.joins(:list)
|
|
|
|
.exists?(
|
|
|
|
account_id: target_account.id,
|
2024-04-17 08:23:25 +00:00
|
|
|
list: { title: list_name }
|
2024-03-15 09:31:25 +00:00
|
|
|
)
|
|
|
|
end
|
2023-06-01 12:47:31 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
context 'when the list does not exist yet' do
|
|
|
|
include_examples 'common behavior'
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when the list exists' do
|
|
|
|
before do
|
2024-04-17 08:23:25 +00:00
|
|
|
Fabricate(:list, account: account, title: list_name)
|
2023-06-01 12:47:31 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
include_examples 'common behavior'
|
2023-08-07 15:59:20 +00:00
|
|
|
|
|
|
|
it 'does not create a new list' do
|
|
|
|
account.follow!(target_account)
|
|
|
|
|
2024-04-17 08:23:25 +00:00
|
|
|
expect { subject.call(import_row) }.to_not(change { List.where(title: list_name).count })
|
2023-08-07 15:59:20 +00:00
|
|
|
end
|
2023-06-01 12:47:31 +00:00
|
|
|
end
|
|
|
|
end
|
2023-05-02 10:08:48 +00:00
|
|
|
end
|
|
|
|
end
|