Expand spec coverage and refactor the Account.find_
methods (#3485)
* Move specs for account finder methods to concern spec * Move account finder methods to concern * Improve spec wording * Use more explicit comparison to ensure correct return value * Add coverage for .find_local! and .find_remote! * Add some methods to the finder * Use arel on matching_username method * Avoid ternary in matching domain method * Simplify finder methods * Use an AccountFinder class to simplify lookup
This commit is contained in:
parent
bf811e4d4a
commit
2cc3111a77
4 changed files with 152 additions and 69 deletions
|
@ -301,54 +301,6 @@ RSpec.describe Account, type: :model do
|
|||
end
|
||||
end
|
||||
|
||||
describe '.find_local' do
|
||||
before do
|
||||
Fabricate(:account, username: 'Alice')
|
||||
end
|
||||
|
||||
it 'returns Alice for alice' do
|
||||
expect(Account.find_local('alice')).to_not be_nil
|
||||
end
|
||||
|
||||
it 'returns Alice for Alice' do
|
||||
expect(Account.find_local('Alice')).to_not be_nil
|
||||
end
|
||||
|
||||
it 'does not return anything for a_ice' do
|
||||
expect(Account.find_local('a_ice')).to be_nil
|
||||
end
|
||||
|
||||
it 'does not return anything for al%' do
|
||||
expect(Account.find_local('al%')).to be_nil
|
||||
end
|
||||
end
|
||||
|
||||
describe '.find_remote' do
|
||||
before do
|
||||
Fabricate(:account, username: 'Alice', domain: 'mastodon.social')
|
||||
end
|
||||
|
||||
it 'returns Alice for alice@mastodon.social' do
|
||||
expect(Account.find_remote('alice', 'mastodon.social')).to_not be_nil
|
||||
end
|
||||
|
||||
it 'returns Alice for ALICE@MASTODON.SOCIAL' do
|
||||
expect(Account.find_remote('ALICE', 'MASTODON.SOCIAL')).to_not be_nil
|
||||
end
|
||||
|
||||
it 'does not return anything for a_ice@mastodon.social' do
|
||||
expect(Account.find_remote('a_ice', 'mastodon.social')).to be_nil
|
||||
end
|
||||
|
||||
it 'does not return anything for alice@m_stodon.social' do
|
||||
expect(Account.find_remote('alice', 'm_stodon.social')).to be_nil
|
||||
end
|
||||
|
||||
it 'does not return anything for alice@m%' do
|
||||
expect(Account.find_remote('alice', 'm%')).to be_nil
|
||||
end
|
||||
end
|
||||
|
||||
describe '.following_map' do
|
||||
it 'returns an hash' do
|
||||
expect(Account.following_map([], 1)).to be_a Hash
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue