Move followable_by coverage to suggestions (#28697)

This commit is contained in:
Matt Jankowski 2024-01-12 04:11:34 -05:00 committed by GitHub
parent 32eeca9c7b
commit cd37048439
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 63 additions and 23 deletions

View file

@ -0,0 +1,6 @@
# frozen_string_literal: true
Fabricator(:follow_recommendation_mute) do
account { Fabricate.build(:account) }
target_account { Fabricate.build(:account) }
end

View file

@ -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

View file

@ -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