Fix deprecation warning about merging conditions (#23618)
parent
9da52ac044
commit
af578e8ce0
|
@ -17,13 +17,13 @@ class AccountFilter
|
||||||
attr_reader :params
|
attr_reader :params
|
||||||
|
|
||||||
def initialize(params)
|
def initialize(params)
|
||||||
@params = params
|
@params = params.to_h.symbolize_keys
|
||||||
end
|
end
|
||||||
|
|
||||||
def results
|
def results
|
||||||
scope = Account.includes(:account_stat, user: [:ips, :invite_request]).without_instance_actor.reorder(nil)
|
scope = Account.includes(:account_stat, user: [:ips, :invite_request]).without_instance_actor.reorder(nil)
|
||||||
|
|
||||||
params.each do |key, value|
|
relevant_params.each do |key, value|
|
||||||
next if key.to_s == 'page'
|
next if key.to_s == 'page'
|
||||||
|
|
||||||
scope.merge!(scope_for(key, value)) if value.present?
|
scope.merge!(scope_for(key, value)) if value.present?
|
||||||
|
@ -34,6 +34,16 @@ class AccountFilter
|
||||||
|
|
||||||
private
|
private
|
||||||
|
|
||||||
|
def relevant_params
|
||||||
|
params.tap do |args|
|
||||||
|
args.delete(:origin) if origin_is_remote_and_domain_present?
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def origin_is_remote_and_domain_present?
|
||||||
|
params[:origin] == 'remote' && params[:by_domain].present?
|
||||||
|
end
|
||||||
|
|
||||||
def scope_for(key, value)
|
def scope_for(key, value)
|
||||||
case key.to_s
|
case key.to_s
|
||||||
when 'origin'
|
when 'origin'
|
||||||
|
@ -94,7 +104,15 @@ class AccountFilter
|
||||||
def order_scope(value)
|
def order_scope(value)
|
||||||
case value.to_s
|
case value.to_s
|
||||||
when 'active'
|
when 'active'
|
||||||
accounts_with_users.left_joins(:account_stat).order(Arel.sql('coalesce(users.current_sign_in_at, account_stats.last_status_at, to_timestamp(0)) desc, accounts.id desc'))
|
accounts_with_users
|
||||||
|
.left_joins(:account_stat)
|
||||||
|
.order(
|
||||||
|
Arel.sql(
|
||||||
|
<<~SQL.squish
|
||||||
|
COALESCE(users.current_sign_in_at, account_stats.last_status_at, to_timestamp(0)) DESC, accounts.id DESC
|
||||||
|
SQL
|
||||||
|
)
|
||||||
|
)
|
||||||
when 'recent'
|
when 'recent'
|
||||||
Account.recent
|
Account.recent
|
||||||
else
|
else
|
||||||
|
|
|
@ -18,4 +18,30 @@ describe AccountFilter do
|
||||||
expect { filter.results }.to raise_error(/wrong/)
|
expect { filter.results }.to raise_error(/wrong/)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
describe 'with origin and by_domain interacting' do
|
||||||
|
let!(:local_account) { Fabricate(:account, domain: nil) }
|
||||||
|
let!(:remote_account_one) { Fabricate(:account, domain: 'example.org') }
|
||||||
|
let(:remote_account_two) { Fabricate(:account, domain: 'other.domain') }
|
||||||
|
|
||||||
|
it 'works with domain first and origin remote' do
|
||||||
|
filter = described_class.new(by_domain: 'example.org', origin: 'remote')
|
||||||
|
expect(filter.results).to match_array [remote_account_one]
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'works with domain last and origin remote' do
|
||||||
|
filter = described_class.new(origin: 'remote', by_domain: 'example.org')
|
||||||
|
expect(filter.results).to match_array [remote_account_one]
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'works with domain first and origin local' do
|
||||||
|
filter = described_class.new(by_domain: 'example.org', origin: 'local')
|
||||||
|
expect(filter.results).to match_array [local_account]
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'works with domain last and origin local' do
|
||||||
|
filter = described_class.new(origin: 'local', by_domain: 'example.org')
|
||||||
|
expect(filter.results).to match_array [remote_account_one]
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in New Issue