| 
									
										
										
										
											2017-04-15 01:17:07 +00:00
										 |  |  | require 'rails_helper' | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-02 16:58:48 +00:00
										 |  |  | describe AccountSearchService, type: :service do | 
					
						
							| 
									
										
										
										
											2017-04-15 01:17:07 +00:00
										 |  |  |   describe '.call' do | 
					
						
							|  |  |  |     describe 'with a query to ignore' do | 
					
						
							|  |  |  |       it 'returns empty array for missing query' do | 
					
						
							|  |  |  |         results = subject.call('', 10) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         expect(results).to eq [] | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |       it 'returns empty array for hashtag query' do | 
					
						
							|  |  |  |         results = subject.call('#tag', 10) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-25 02:44:43 +00:00
										 |  |  |         expect(results).to eq [] | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |       it 'returns empty array for limit zero' do | 
					
						
							|  |  |  |         Fabricate(:account, username: 'match') | 
					
						
							|  |  |  |         results = subject.call('match', 0) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-15 01:17:07 +00:00
										 |  |  |         expect(results).to eq [] | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     describe 'searching for a simple term that is not an exact match' do | 
					
						
							|  |  |  |       it 'does not return a nil entry in the array for the exact match' do | 
					
						
							|  |  |  |         match = Fabricate(:account, username: 'matchingusername') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         results = subject.call('match', 5) | 
					
						
							|  |  |  |         expect(results).to eq [match] | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     describe 'searching local and remote users' do | 
					
						
							| 
									
										
										
										
											2017-04-17 17:57:02 +00:00
										 |  |  |       describe "when only '@'" do | 
					
						
							|  |  |  |         before do | 
					
						
							| 
									
										
										
										
											2017-05-26 22:55:08 +00:00
										 |  |  |           allow(Account).to receive(:find_local) | 
					
						
							| 
									
										
										
										
											2017-04-17 17:57:02 +00:00
										 |  |  |           allow(Account).to receive(:search_for) | 
					
						
							|  |  |  |           subject.call('@', 10) | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-26 22:55:08 +00:00
										 |  |  |         it 'uses find_local with empty query to look for local accounts' do | 
					
						
							|  |  |  |           expect(Account).to have_received(:find_local).with('') | 
					
						
							| 
									
										
										
										
											2017-04-17 17:57:02 +00:00
										 |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-15 01:17:07 +00:00
										 |  |  |       describe 'when no domain' do | 
					
						
							|  |  |  |         before do | 
					
						
							| 
									
										
										
										
											2017-05-26 22:55:08 +00:00
										 |  |  |           allow(Account).to receive(:find_local) | 
					
						
							| 
									
										
										
										
											2017-04-15 01:17:07 +00:00
										 |  |  |           allow(Account).to receive(:search_for) | 
					
						
							|  |  |  |           subject.call('one', 10) | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-26 22:55:08 +00:00
										 |  |  |         it 'uses find_local to look for local accounts' do | 
					
						
							|  |  |  |           expect(Account).to have_received(:find_local).with('one') | 
					
						
							| 
									
										
										
										
											2017-04-15 01:17:07 +00:00
										 |  |  |         end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         it 'uses search_for to find matches' do | 
					
						
							|  |  |  |           expect(Account).to have_received(:search_for).with('one', 10) | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       describe 'when there is a domain' do | 
					
						
							|  |  |  |         before do | 
					
						
							|  |  |  |           allow(Account).to receive(:find_remote) | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         it 'uses find_remote to look for remote accounts' do | 
					
						
							|  |  |  |           subject.call('two@example.com', 10) | 
					
						
							|  |  |  |           expect(Account).to have_received(:find_remote).with('two', 'example.com') | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         describe 'and there is no account provided' do | 
					
						
							|  |  |  |           it 'uses search_for to find matches' do | 
					
						
							|  |  |  |             allow(Account).to receive(:search_for) | 
					
						
							| 
									
										
										
										
											2017-12-05 22:02:27 +00:00
										 |  |  |             subject.call('two@example.com', 10, nil, resolve: false) | 
					
						
							| 
									
										
										
										
											2017-04-15 01:17:07 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |             expect(Account).to have_received(:search_for).with('two example.com', 10) | 
					
						
							|  |  |  |           end | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         describe 'and there is an account provided' do | 
					
						
							|  |  |  |           it 'uses advanced_search_for to find matches' do | 
					
						
							|  |  |  |             account = Fabricate(:account) | 
					
						
							|  |  |  |             allow(Account).to receive(:advanced_search_for) | 
					
						
							| 
									
										
										
										
											2017-12-05 22:02:27 +00:00
										 |  |  |             subject.call('two@example.com', 10, account, resolve: false) | 
					
						
							| 
									
										
										
										
											2017-04-15 01:17:07 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-05 22:02:27 +00:00
										 |  |  |             expect(Account).to have_received(:advanced_search_for).with('two example.com', account, 10, nil) | 
					
						
							| 
									
										
										
										
											2017-04-15 01:17:07 +00:00
										 |  |  |           end | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     describe 'with an exact match' do | 
					
						
							|  |  |  |       it 'returns exact match first, and does not return duplicates' do | 
					
						
							|  |  |  |         partial = Fabricate(:account, username: 'exactness') | 
					
						
							|  |  |  |         exact = Fabricate(:account, username: 'exact') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         results = subject.call('exact', 10) | 
					
						
							|  |  |  |         expect(results.size).to eq 2
 | 
					
						
							|  |  |  |         expect(results).to eq [exact, partial] | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-26 22:55:08 +00:00
										 |  |  |     describe 'when there is a local domain' do | 
					
						
							|  |  |  |       around do |example| | 
					
						
							|  |  |  |         before = Rails.configuration.x.local_domain | 
					
						
							|  |  |  |         example.run | 
					
						
							|  |  |  |         Rails.configuration.x.local_domain = before | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it 'returns exact match first' do | 
					
						
							|  |  |  |         remote     = Fabricate(:account, username: 'a', domain: 'remote', display_name: 'e') | 
					
						
							|  |  |  |         remote_too = Fabricate(:account, username: 'b', domain: 'remote', display_name: 'e') | 
					
						
							|  |  |  |         exact = Fabricate(:account, username: 'e') | 
					
						
							|  |  |  |         Rails.configuration.x.local_domain = 'example.com' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         results = subject.call('e@example.com', 2) | 
					
						
							|  |  |  |         expect(results.size).to eq 2
 | 
					
						
							|  |  |  |         expect(results).to eq([exact, remote]).or eq([exact, remote_too]) | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-15 01:17:07 +00:00
										 |  |  |     describe 'when there is a domain but no exact match' do | 
					
						
							|  |  |  |       it 'follows the remote account when resolve is true' do | 
					
						
							|  |  |  |         service = double(call: nil) | 
					
						
							| 
									
										
										
										
											2018-01-22 13:25:09 +00:00
										 |  |  |         allow(ResolveAccountService).to receive(:new).and_return(service) | 
					
						
							| 
									
										
										
										
											2017-04-15 01:17:07 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-05 22:02:27 +00:00
										 |  |  |         results = subject.call('newuser@remote.com', 10, nil, resolve: true) | 
					
						
							| 
									
										
										
										
											2017-04-15 01:17:07 +00:00
										 |  |  |         expect(service).to have_received(:call).with('newuser@remote.com') | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it 'does not follow the remote account when resolve is false' do | 
					
						
							|  |  |  |         service = double(call: nil) | 
					
						
							| 
									
										
										
										
											2018-01-22 13:25:09 +00:00
										 |  |  |         allow(ResolveAccountService).to receive(:new).and_return(service) | 
					
						
							| 
									
										
										
										
											2017-04-15 01:17:07 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-05 22:02:27 +00:00
										 |  |  |         results = subject.call('newuser@remote.com', 10, nil, resolve: false) | 
					
						
							| 
									
										
										
										
											2017-04-15 01:17:07 +00:00
										 |  |  |         expect(service).not_to have_received(:call) | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							| 
									
										
										
										
											2018-04-23 19:27:18 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     describe 'should not include suspended accounts' do | 
					
						
							|  |  |  |       it 'returns the fuzzy match first, and does not return suspended exacts' do | 
					
						
							|  |  |  |         partial = Fabricate(:account, username: 'exactness') | 
					
						
							|  |  |  |         exact = Fabricate(:account, username: 'exact', suspended: true) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         results = subject.call('exact', 10) | 
					
						
							|  |  |  |         expect(results.size).to eq 1
 | 
					
						
							|  |  |  |         expect(results).to eq [partial] | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it "does not return suspended remote accounts" do | 
					
						
							|  |  |  |         remote = Fabricate(:account, username: 'a', domain: 'remote', display_name: 'e', suspended: true) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         results = subject.call('a@example.com', 2) | 
					
						
							|  |  |  |         expect(results.size).to eq 0
 | 
					
						
							|  |  |  |         expect(results).to eq [] | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							| 
									
										
										
										
											2017-04-15 01:17:07 +00:00
										 |  |  |   end | 
					
						
							|  |  |  | end |