123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135 |
- # frozen_string_literal: true
- require 'rails_helper'
- describe Api::V1::DirectoriesController do
- render_views
- let(:user) { Fabricate(:user, confirmed_at: nil) }
- let(:token) { Fabricate(:accessible_access_token, resource_owner_id: user.id, scopes: 'read:follows') }
- before do
- allow(controller).to receive(:doorkeeper_token) { token }
- end
- describe 'GET #show' do
- context 'with no params' do
- before do
- local_unconfirmed_account = Fabricate(
- :account,
- domain: nil,
- user: Fabricate(:user, confirmed_at: nil, approved: true),
- username: 'local_unconfirmed'
- )
- local_unconfirmed_account.create_account_stat!
- local_unapproved_account = Fabricate(
- :account,
- domain: nil,
- user: Fabricate(:user, confirmed_at: 10.days.ago),
- username: 'local_unapproved'
- )
- local_unapproved_account.create_account_stat!
- local_unapproved_account.user.update(approved: false)
- local_undiscoverable_account = Fabricate(
- :account,
- domain: nil,
- user: Fabricate(:user, confirmed_at: 10.days.ago, approved: true),
- discoverable: false,
- username: 'local_undiscoverable'
- )
- local_undiscoverable_account.create_account_stat!
- excluded_from_timeline_account = Fabricate(
- :account,
- domain: 'host.example',
- discoverable: true,
- username: 'remote_excluded_from_timeline'
- )
- excluded_from_timeline_account.create_account_stat!
- Fabricate(:block, account: user.account, target_account: excluded_from_timeline_account)
- domain_blocked_account = Fabricate(
- :account,
- domain: 'test.example',
- discoverable: true,
- username: 'remote_domain_blocked'
- )
- domain_blocked_account.create_account_stat!
- Fabricate(:account_domain_block, account: user.account, domain: 'test.example')
- end
- it 'returns the local discoverable account and the remote discoverable account' do
- local_discoverable_account = Fabricate(
- :account,
- domain: nil,
- user: Fabricate(:user, confirmed_at: 10.days.ago, approved: true),
- discoverable: true,
- username: 'local_discoverable'
- )
- local_discoverable_account.create_account_stat!
- eligible_remote_account = Fabricate(
- :account,
- domain: 'host.example',
- discoverable: true,
- username: 'eligible_remote'
- )
- eligible_remote_account.create_account_stat!
- get :show
- expect(response).to have_http_status(200)
- expect(body_as_json.size).to eq(2)
- expect(body_as_json.pluck(:id)).to contain_exactly(eligible_remote_account.id.to_s, local_discoverable_account.id.to_s)
- end
- end
- context 'when asking for local accounts only' do
- it 'returns only the local accounts' do
- user = Fabricate(:user, confirmed_at: 10.days.ago, approved: true)
- local_account = Fabricate(:account, domain: nil, user: user)
- remote_account = Fabricate(:account, domain: 'host.example')
- local_account.create_account_stat!
- remote_account.create_account_stat!
- get :show, params: { local: '1' }
- expect(response).to have_http_status(200)
- expect(body_as_json.size).to eq(1)
- expect(body_as_json.first[:id]).to include(local_account.id.to_s)
- expect(response.body).to_not include(remote_account.id.to_s)
- end
- end
- context 'when ordered by active' do
- it 'returns accounts in order of most recent status activity' do
- old_stat = Fabricate(:account_stat, last_status_at: 1.day.ago)
- new_stat = Fabricate(:account_stat, last_status_at: 1.minute.ago)
- get :show, params: { order: 'active' }
- expect(response).to have_http_status(200)
- expect(body_as_json.size).to eq(2)
- expect(body_as_json.first[:id]).to include(new_stat.account_id.to_s)
- expect(body_as_json.second[:id]).to include(old_stat.account_id.to_s)
- end
- end
- context 'when ordered by new' do
- it 'returns accounts in order of creation' do
- account_old = Fabricate(:account_stat).account
- travel_to 10.seconds.from_now
- account_new = Fabricate(:account_stat).account
- get :show, params: { order: 'new' }
- expect(response).to have_http_status(200)
- expect(body_as_json.size).to eq(2)
- expect(body_as_json.first[:id]).to include(account_new.id.to_s)
- expect(body_as_json.second[:id]).to include(account_old.id.to_s)
- end
- end
- end
- end
|