1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495 |
- # frozen_string_literal: true
- require 'rails_helper'
- RSpec.describe Api::V2::SearchController do
- render_views
- context 'with token' do
- let(:user) { Fabricate(:user) }
- let(:token) { Fabricate(:accessible_access_token, resource_owner_id: user.id, scopes: 'read:search') }
- before do
- allow(controller).to receive(:doorkeeper_token) { token }
- end
- describe 'GET #index' do
- 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
- context 'without token' do
- describe 'GET #index' do
- let(:search_params) {}
- before do
- get :index, params: search_params
- end
- context 'with a `q` shorter than 5 characters' do
- let(:search_params) { { q: 'test' } }
- it 'returns http success' do
- expect(response).to have_http_status(200)
- end
- end
- context 'with a `q` equal to or longer than 5 characters' do
- let(:search_params) { { q: 'test1' } }
- it 'returns http success' do
- expect(response).to have_http_status(200)
- end
- context 'with truthy `resolve`' do
- let(:search_params) { { q: 'test1', resolve: '1' } }
- it 'returns http unauthorized' do
- expect(response).to have_http_status(401)
- end
- end
- context 'with `offset`' do
- let(:search_params) { { q: 'test1', offset: 1 } }
- it 'returns http unauthorized' do
- expect(response).to have_http_status(401)
- end
- end
- end
- end
- end
- end
|