forked from treehouse/mastodon
Move followable_by coverage to suggestions (#28697)
parent
32eeca9c7b
commit
cd37048439
|
@ -0,0 +1,6 @@
|
||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
|
Fabricator(:follow_recommendation_mute) do
|
||||||
|
account { Fabricate.build(:account) }
|
||||||
|
target_account { Fabricate.build(:account) }
|
||||||
|
end
|
|
@ -1011,27 +1011,4 @@ RSpec.describe Account do
|
||||||
expect(subject.reload.followers_count).to eq 15
|
expect(subject.reload.followers_count).to eq 15
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
describe '.followable_by' do
|
|
||||||
context 'with follows and follow requests' do
|
|
||||||
let!(:account) { Fabricate(:account) }
|
|
||||||
let!(:eligible_account) { Fabricate(:account) }
|
|
||||||
let!(:following_account) { Fabricate(:account) }
|
|
||||||
let!(:follow_requested_account) { Fabricate(:account) }
|
|
||||||
|
|
||||||
before do
|
|
||||||
Fabricate :follow, account: account, target_account: following_account
|
|
||||||
Fabricate :follow_request, account: account, target_account: follow_requested_account
|
|
||||||
end
|
|
||||||
|
|
||||||
it 'returns accounts not already following or requested to follow' do
|
|
||||||
results = described_class.followable_by(account)
|
|
||||||
|
|
||||||
expect(results)
|
|
||||||
.to include(eligible_account)
|
|
||||||
.and not_include(following_account)
|
|
||||||
.and not_include(follow_requested_account)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
|
@ -0,0 +1,57 @@
|
||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
|
require 'rails_helper'
|
||||||
|
|
||||||
|
RSpec.describe AccountSuggestions::Source do
|
||||||
|
describe '#base_account_scope' do
|
||||||
|
subject { FakeSource.new }
|
||||||
|
|
||||||
|
before do
|
||||||
|
stub_const 'FakeSource', fake_source_class
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'with follows and follow requests' do
|
||||||
|
let!(:account_domain_blocked_account) { Fabricate(:account, domain: 'blocked.host') }
|
||||||
|
let!(:account) { Fabricate(:account) }
|
||||||
|
let!(:blocked_account) { Fabricate(:account) }
|
||||||
|
let!(:eligible_account) { Fabricate(:account) }
|
||||||
|
let!(:follow_recommendation_muted_account) { Fabricate(:account) }
|
||||||
|
let!(:follow_requested_account) { Fabricate(:account) }
|
||||||
|
let!(:following_account) { Fabricate(:account) }
|
||||||
|
let!(:moved_account) { Fabricate(:account, moved_to_account: Fabricate(:account)) }
|
||||||
|
|
||||||
|
before do
|
||||||
|
Fabricate :account_domain_block, account: account, domain: account_domain_blocked_account.domain
|
||||||
|
Fabricate :block, account: account, target_account: blocked_account
|
||||||
|
Fabricate :follow_recommendation_mute, account: account, target_account: follow_recommendation_muted_account
|
||||||
|
Fabricate :follow_request, account: account, target_account: follow_requested_account
|
||||||
|
Fabricate :follow, account: account, target_account: following_account
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'returns eligible accounts' do
|
||||||
|
results = subject.get(account)
|
||||||
|
|
||||||
|
expect(results)
|
||||||
|
.to include(eligible_account)
|
||||||
|
.and not_include(account_domain_blocked_account)
|
||||||
|
.and not_include(account)
|
||||||
|
.and not_include(blocked_account)
|
||||||
|
.and not_include(follow_recommendation_muted_account)
|
||||||
|
.and not_include(follow_requested_account)
|
||||||
|
.and not_include(following_account)
|
||||||
|
.and not_include(moved_account)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
private
|
||||||
|
|
||||||
|
def fake_source_class
|
||||||
|
Class.new described_class do
|
||||||
|
def get(account, limit: 10)
|
||||||
|
base_account_scope(account)
|
||||||
|
.limit(limit)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
Loading…
Reference in New Issue