Commit 6b8a8a50 authored by Mayra Cabrera's avatar Mayra Cabrera

Merge branch 'Add_by_saml_provider_id_model_scope_and_db_finder_for_User' into 'master'

Add SAML provider search to UsersFinder

See merge request gitlab-org/gitlab!66162
parents 113aac25 cfa3e79e
...@@ -6,7 +6,8 @@ module EE ...@@ -6,7 +6,8 @@ module EE
override :execute override :execute
def execute def execute
by_non_ldap(super) users = by_non_ldap(super)
by_saml_provider_id(users)
end end
def by_non_ldap(users) def by_non_ldap(users)
...@@ -14,5 +15,12 @@ module EE ...@@ -14,5 +15,12 @@ module EE
users.non_ldap users.non_ldap
end end
def by_saml_provider_id(users)
saml_provider_id = params[:by_saml_provider_id]
return users unless saml_provider_id
users.limit_to_saml_provider(saml_provider_id)
end
end end
end end
...@@ -8,7 +8,7 @@ RSpec.describe UsersFinder do ...@@ -8,7 +8,7 @@ RSpec.describe UsersFinder do
context 'with a normal user' do context 'with a normal user' do
context 'with LDAP users' do context 'with LDAP users' do
let!(:ldap_user) { create(:omniauth_user, provider: 'ldap') } let_it_be(:ldap_user) { create(:omniauth_user, provider: 'ldap') }
it 'returns ldap users by default' do it 'returns ldap users by default' do
users = described_class.new(normal_user).execute users = described_class.new(normal_user).execute
...@@ -22,6 +22,29 @@ RSpec.describe UsersFinder do ...@@ -22,6 +22,29 @@ RSpec.describe UsersFinder do
expect(users).to contain_exactly(normal_user, blocked_user, omniauth_user, external_user, internal_user, admin_user) expect(users).to contain_exactly(normal_user, blocked_user, omniauth_user, external_user, internal_user, admin_user)
end end
end end
context 'with SAML users' do
let_it_be(:group) { create(:group) }
let_it_be(:saml_provider) { create(:saml_provider, group: group, enabled: true, enforced_sso: true) }
let_it_be(:saml_user) { create(:user) }
let_it_be(:non_saml_user) { create(:user) }
before do
create(:identity, provider: 'group_saml1', saml_provider_id: saml_provider.id, user: saml_user)
end
it 'returns all users by default' do
users = described_class.new(normal_user).execute
expect(users).to contain_exactly(normal_user, blocked_user, omniauth_user, external_user, internal_user, admin_user, saml_user, non_saml_user)
end
it 'returns only saml users from the provided saml_provider_id' do
users = described_class.new(normal_user, by_saml_provider_id: saml_provider.id).execute
expect(users).to contain_exactly(saml_user)
end
end
end end
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