Fix call to inefficient delete_matched
cache method in domain blocks (#28374)
This commit is contained in:
parent
f4b9c2ba40
commit
7d9b209fe8
11 changed files with 96 additions and 50 deletions
|
@ -5,19 +5,18 @@ require 'rails_helper'
|
|||
RSpec.describe AccountRelationshipsPresenter do
|
||||
describe '.initialize' do
|
||||
before do
|
||||
allow(Account).to receive(:following_map).with(account_ids, current_account_id).and_return(default_map)
|
||||
allow(Account).to receive(:followed_by_map).with(account_ids, current_account_id).and_return(default_map)
|
||||
allow(Account).to receive(:blocking_map).with(account_ids, current_account_id).and_return(default_map)
|
||||
allow(Account).to receive(:muting_map).with(account_ids, current_account_id).and_return(default_map)
|
||||
allow(Account).to receive(:requested_map).with(account_ids, current_account_id).and_return(default_map)
|
||||
allow(Account).to receive(:requested_by_map).with(account_ids, current_account_id).and_return(default_map)
|
||||
allow(Account).to receive(:domain_blocking_map).with(account_ids, current_account_id).and_return(default_map)
|
||||
allow(Account).to receive(:following_map).with(accounts.pluck(:id), current_account_id).and_return(default_map)
|
||||
allow(Account).to receive(:followed_by_map).with(accounts.pluck(:id), current_account_id).and_return(default_map)
|
||||
allow(Account).to receive(:blocking_map).with(accounts.pluck(:id), current_account_id).and_return(default_map)
|
||||
allow(Account).to receive(:muting_map).with(accounts.pluck(:id), current_account_id).and_return(default_map)
|
||||
allow(Account).to receive(:requested_map).with(accounts.pluck(:id), current_account_id).and_return(default_map)
|
||||
allow(Account).to receive(:requested_by_map).with(accounts.pluck(:id), current_account_id).and_return(default_map)
|
||||
end
|
||||
|
||||
let(:presenter) { described_class.new(account_ids, current_account_id, **options) }
|
||||
let(:presenter) { described_class.new(accounts, current_account_id, **options) }
|
||||
let(:current_account_id) { Fabricate(:account).id }
|
||||
let(:account_ids) { [Fabricate(:account).id] }
|
||||
let(:default_map) { { 1 => true } }
|
||||
let(:accounts) { [Fabricate(:account)] }
|
||||
let(:default_map) { { accounts[0].id => true } }
|
||||
|
||||
context 'when options are not set' do
|
||||
let(:options) { {} }
|
||||
|
@ -29,7 +28,33 @@ RSpec.describe AccountRelationshipsPresenter do
|
|||
blocking: default_map,
|
||||
muting: default_map,
|
||||
requested: default_map,
|
||||
domain_blocking: default_map
|
||||
domain_blocking: { accounts[0].id => nil }
|
||||
)
|
||||
end
|
||||
end
|
||||
|
||||
context 'with a warm cache' do
|
||||
let(:options) { {} }
|
||||
|
||||
before do
|
||||
described_class.new(accounts, current_account_id, **options)
|
||||
|
||||
allow(Account).to receive(:following_map).with([], current_account_id).and_return({})
|
||||
allow(Account).to receive(:followed_by_map).with([], current_account_id).and_return({})
|
||||
allow(Account).to receive(:blocking_map).with([], current_account_id).and_return({})
|
||||
allow(Account).to receive(:muting_map).with([], current_account_id).and_return({})
|
||||
allow(Account).to receive(:requested_map).with([], current_account_id).and_return({})
|
||||
allow(Account).to receive(:requested_by_map).with([], current_account_id).and_return({})
|
||||
end
|
||||
|
||||
it 'sets returns expected values' do
|
||||
expect(presenter).to have_attributes(
|
||||
following: default_map,
|
||||
followed_by: default_map,
|
||||
blocking: default_map,
|
||||
muting: default_map,
|
||||
requested: default_map,
|
||||
domain_blocking: { accounts[0].id => nil }
|
||||
)
|
||||
end
|
||||
end
|
||||
|
@ -86,7 +111,7 @@ RSpec.describe AccountRelationshipsPresenter do
|
|||
let(:options) { { domain_blocking_map: { 7 => true } } }
|
||||
|
||||
it 'sets @domain_blocking merged with default_map and options[:domain_blocking_map]' do
|
||||
expect(presenter.domain_blocking).to eq default_map.merge(options[:domain_blocking_map])
|
||||
expect(presenter.domain_blocking).to eq({ accounts[0].id => nil }.merge(options[:domain_blocking_map]))
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue