Commit dbb4caf5 authored by Catalin Irimie's avatar Catalin Irimie

Update user search tests to let_it_be, no delegate

parent 11e728c3
...@@ -2024,10 +2024,10 @@ RSpec.describe User do ...@@ -2024,10 +2024,10 @@ RSpec.describe User do
end end
describe '.search' do describe '.search' do
let!(:user) { create(:user, name: 'user', username: 'usern', email: 'email@gmail.com') } let_it_be(:user) { create(:user, name: 'user', username: 'usern', email: 'email@gmail.com') }
let!(:user2) { create(:user, name: 'user name', username: 'username', email: 'someemail@gmail.com') } let_it_be(:user2) { create(:user, name: 'user name', username: 'username', email: 'someemail@gmail.com') }
let!(:user3) { create(:user, name: 'us', username: 'se', email: 'foo@gmail.com') } let_it_be(:user3) { create(:user, name: 'us', username: 'se', email: 'foo@gmail.com') }
let!(:email) do let_it_be(:email) do
create(:email, user: user, email: 'alias@example.com') create(:email, user: user, email: 'alias@example.com')
end end
...@@ -2137,126 +2137,122 @@ RSpec.describe User do ...@@ -2137,126 +2137,122 @@ RSpec.describe User do
end end
describe '.search_without_secondary_emails' do describe '.search_without_secondary_emails' do
delegate :search_without_secondary_emails, to: :described_class let_it_be(:user) { create(:user, name: 'John Doe', username: 'john.doe', email: 'someone.1@example.com' ) }
let_it_be(:another_user) { create(:user, name: 'Albert Smith', username: 'albert.smith', email: 'another.2@example.com' ) }
let!(:user) { create(:user, name: 'John Doe', username: 'john.doe', email: 'someone.1@example.com' ) } let_it_be(:email) do
let!(:another_user) { create(:user, name: 'Albert Smith', username: 'albert.smith', email: 'another.2@example.com' ) }
let!(:email) do
create(:email, user: another_user, email: 'alias@example.com') create(:email, user: another_user, email: 'alias@example.com')
end end
it 'returns users with a matching name' do it 'returns users with a matching name' do
expect(search_without_secondary_emails(user.name)).to eq([user]) expect(described_class.search_without_secondary_emails(user.name)).to eq([user])
end end
it 'returns users with a partially matching name' do it 'returns users with a partially matching name' do
expect(search_without_secondary_emails(user.name[0..2])).to eq([user]) expect(described_class.search_without_secondary_emails(user.name[0..2])).to eq([user])
end end
it 'returns users with a matching name regardless of the casing' do it 'returns users with a matching name regardless of the casing' do
expect(search_without_secondary_emails(user.name.upcase)).to eq([user]) expect(described_class.search_without_secondary_emails(user.name.upcase)).to eq([user])
end end
it 'returns users with a matching email' do it 'returns users with a matching email' do
expect(search_without_secondary_emails(user.email)).to eq([user]) expect(described_class.search_without_secondary_emails(user.email)).to eq([user])
end end
it 'does not return users with a partially matching email' do it 'does not return users with a partially matching email' do
expect(search_without_secondary_emails(user.email[0..2])).not_to include(user) expect(described_class.search_without_secondary_emails(user.email[0..2])).not_to include(user)
end end
it 'returns users with a matching email regardless of the casing' do it 'returns users with a matching email regardless of the casing' do
expect(search_without_secondary_emails(user.email.upcase)).to eq([user]) expect(described_class.search_without_secondary_emails(user.email.upcase)).to eq([user])
end end
it 'returns users with a matching username' do it 'returns users with a matching username' do
expect(search_without_secondary_emails(user.username)).to eq([user]) expect(described_class.search_without_secondary_emails(user.username)).to eq([user])
end end
it 'returns users with a partially matching username' do it 'returns users with a partially matching username' do
expect(search_without_secondary_emails(user.username[0..2])).to eq([user]) expect(described_class.search_without_secondary_emails(user.username[0..2])).to eq([user])
end end
it 'returns users with a matching username regardless of the casing' do it 'returns users with a matching username regardless of the casing' do
expect(search_without_secondary_emails(user.username.upcase)).to eq([user]) expect(described_class.search_without_secondary_emails(user.username.upcase)).to eq([user])
end end
it 'does not return users with a matching whole secondary email' do it 'does not return users with a matching whole secondary email' do
expect(search_without_secondary_emails(email.email)).not_to include(email.user) expect(described_class.search_without_secondary_emails(email.email)).not_to include(email.user)
end end
it 'does not return users with a matching part of secondary email' do it 'does not return users with a matching part of secondary email' do
expect(search_without_secondary_emails(email.email[1..4])).not_to include(email.user) expect(described_class.search_without_secondary_emails(email.email[1..4])).not_to include(email.user)
end end
it 'returns no matches for an empty string' do it 'returns no matches for an empty string' do
expect(search_without_secondary_emails('')).to be_empty expect(described_class.search_without_secondary_emails('')).to be_empty
end end
it 'returns no matches for nil' do it 'returns no matches for nil' do
expect(search_without_secondary_emails(nil)).to be_empty expect(described_class.search_without_secondary_emails(nil)).to be_empty
end end
end end
describe '.search_with_secondary_emails' do describe '.search_with_secondary_emails' do
delegate :search_with_secondary_emails, to: :described_class let_it_be(:user) { create(:user, name: 'John Doe', username: 'john.doe', email: 'someone.1@example.com' ) }
let_it_be(:another_user) { create(:user, name: 'Albert Smith', username: 'albert.smith', email: 'another.2@example.com' ) }
let!(:user) { create(:user, name: 'John Doe', username: 'john.doe', email: 'someone.1@example.com' ) } let_it_be(:email) do
let!(:another_user) { create(:user, name: 'Albert Smith', username: 'albert.smith', email: 'another.2@example.com' ) }
let!(:email) do
create(:email, user: another_user, email: 'alias@example.com') create(:email, user: another_user, email: 'alias@example.com')
end end
it 'returns users with a matching name' do it 'returns users with a matching name' do
expect(search_with_secondary_emails(user.name)).to eq([user]) expect(described_class.search_with_secondary_emails(user.name)).to eq([user])
end end
it 'returns users with a partially matching name' do it 'returns users with a partially matching name' do
expect(search_with_secondary_emails(user.name[0..2])).to eq([user]) expect(described_class.search_with_secondary_emails(user.name[0..2])).to eq([user])
end end
it 'returns users with a matching name regardless of the casing' do it 'returns users with a matching name regardless of the casing' do
expect(search_with_secondary_emails(user.name.upcase)).to eq([user]) expect(described_class.search_with_secondary_emails(user.name.upcase)).to eq([user])
end end
it 'returns users with a matching email' do it 'returns users with a matching email' do
expect(search_with_secondary_emails(user.email)).to eq([user]) expect(described_class.search_with_secondary_emails(user.email)).to eq([user])
end end
it 'does not return users with a partially matching email' do it 'does not return users with a partially matching email' do
expect(search_with_secondary_emails(user.email[0..2])).not_to include(user) expect(described_class.search_with_secondary_emails(user.email[0..2])).not_to include(user)
end end
it 'returns users with a matching email regardless of the casing' do it 'returns users with a matching email regardless of the casing' do
expect(search_with_secondary_emails(user.email.upcase)).to eq([user]) expect(described_class.search_with_secondary_emails(user.email.upcase)).to eq([user])
end end
it 'returns users with a matching username' do it 'returns users with a matching username' do
expect(search_with_secondary_emails(user.username)).to eq([user]) expect(described_class.search_with_secondary_emails(user.username)).to eq([user])
end end
it 'returns users with a partially matching username' do it 'returns users with a partially matching username' do
expect(search_with_secondary_emails(user.username[0..2])).to eq([user]) expect(described_class.search_with_secondary_emails(user.username[0..2])).to eq([user])
end end
it 'returns users with a matching username regardless of the casing' do it 'returns users with a matching username regardless of the casing' do
expect(search_with_secondary_emails(user.username.upcase)).to eq([user]) expect(described_class.search_with_secondary_emails(user.username.upcase)).to eq([user])
end end
it 'returns users with a matching whole secondary email' do it 'returns users with a matching whole secondary email' do
expect(search_with_secondary_emails(email.email)).to eq([email.user]) expect(described_class.search_with_secondary_emails(email.email)).to eq([email.user])
end end
it 'does not return users with a matching part of secondary email' do it 'does not return users with a matching part of secondary email' do
expect(search_with_secondary_emails(email.email[1..4])).not_to include(email.user) expect(described_class.search_with_secondary_emails(email.email[1..4])).not_to include(email.user)
end end
it 'returns no matches for an empty string' do it 'returns no matches for an empty string' do
expect(search_with_secondary_emails('')).to be_empty expect(described_class.search_with_secondary_emails('')).to be_empty
end end
it 'returns no matches for nil' do it 'returns no matches for nil' do
expect(search_with_secondary_emails(nil)).to be_empty expect(described_class.search_with_secondary_emails(nil)).to be_empty
end end
end end
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment