Skip to content

Commit

Permalink
Fix /api/v2/search not working with following query param (mastodon…
Browse files Browse the repository at this point in the history
  • Loading branch information
danielmbrasil authored and skerit committed Jul 7, 2023
1 parent 74d3444 commit 3fa4b59
Show file tree
Hide file tree
Showing 4 changed files with 42 additions and 13 deletions.
4 changes: 2 additions & 2 deletions app/controllers/api/v2/search_controller.rb
Expand Up @@ -34,11 +34,11 @@ def search_results
params[:q],
current_account,
limit_param(RESULTS_LIMIT),
search_params.merge(resolve: truthy_param?(:resolve), exclude_unreviewed: truthy_param?(:exclude_unreviewed))
search_params.merge(resolve: truthy_param?(:resolve), exclude_unreviewed: truthy_param?(:exclude_unreviewed), following: truthy_param?(:following))
)
end

def search_params
params.permit(:type, :offset, :min_id, :max_id, :account_id)
params.permit(:type, :offset, :min_id, :max_id, :account_id, :following)
end
end
16 changes: 9 additions & 7 deletions app/services/search_service.rb
Expand Up @@ -2,12 +2,13 @@

class SearchService < BaseService
def call(query, account, limit, options = {})
@query = query&.strip
@account = account
@options = options
@limit = limit.to_i
@offset = options[:type].blank? ? 0 : options[:offset].to_i
@resolve = options[:resolve] || false
@query = query&.strip
@account = account
@options = options
@limit = limit.to_i
@offset = options[:type].blank? ? 0 : options[:offset].to_i
@resolve = options[:resolve] || false
@following = options[:following] || false

default_results.tap do |results|
next if @query.blank? || @limit.zero?
Expand All @@ -31,7 +32,8 @@ def perform_accounts_search!
limit: @limit,
resolve: @resolve,
offset: @offset,
use_searchable_text: true
use_searchable_text: true,
following: @following
)
end

Expand Down
33 changes: 30 additions & 3 deletions spec/controllers/api/v2/search_controller_spec.rb
Expand Up @@ -14,13 +14,40 @@
end

describe 'GET #index' do
before do
get :index, params: { q: 'test' }
end
let!(:bob) { Fabricate(:account, username: 'bob_test') }
let!(:ana) { Fabricate(:account, username: 'ana_test') }
let!(:tom) { Fabricate(:account, username: 'tom_test') }
let(:params) { { q: 'test' } }

it 'returns http success' do
get :index, params: params

expect(response).to have_http_status(200)
end

context 'when searching accounts' do
let(:params) { { q: 'test', type: 'accounts' } }

it 'returns all matching accounts' do
get :index, params: params

expect(body_as_json[:accounts].pluck(:id)).to contain_exactly(bob.id.to_s, ana.id.to_s, tom.id.to_s)
end

context 'with following=true' do
let(:params) { { q: 'test', type: 'accounts', following: 'true' } }

before do
user.account.follow!(ana)
end

it 'returns only the followed accounts' do
get :index, params: params

expect(body_as_json[:accounts].pluck(:id)).to contain_exactly(ana.id.to_s)
end
end
end
end
end

Expand Down
2 changes: 1 addition & 1 deletion spec/services/search_service_spec.rb
Expand Up @@ -68,7 +68,7 @@
allow(AccountSearchService).to receive(:new).and_return(service)

results = subject.call(query, nil, 10)
expect(service).to have_received(:call).with(query, nil, limit: 10, offset: 0, resolve: false, use_searchable_text: true)
expect(service).to have_received(:call).with(query, nil, limit: 10, offset: 0, resolve: false, use_searchable_text: true, following: false)
expect(results).to eq empty_results.merge(accounts: [account])
end
end
Expand Down

0 comments on commit 3fa4b59

Please sign in to comment.