Commit e12a311d authored by Sanad Liaquat's avatar Sanad Liaquat

Merge branch 'qa-shl-refactor-and-stablize-ldap-specs' into 'master'

Stablize and refactor LDAP e2e specs

See merge request gitlab-org/gitlab!43574
parents 49eed155 dfafc734
...@@ -5,6 +5,12 @@ module QA ...@@ -5,6 +5,12 @@ module QA
describe 'LDAP Group sync' do describe 'LDAP Group sync' do
include Support::Api include Support::Api
let(:group) do
Resource::Group.fabricate_via_api! do |resource|
resource.path = "#{group_name}-#{SecureRandom.hex(4)}"
end
end
before(:all) do before(:all) do
# Create the sandbox group as the LDAP user. Without this the admin user # Create the sandbox group as the LDAP user. Without this the admin user
# would own the sandbox group and then in subsequent tests the LDAP user # would own the sandbox group and then in subsequent tests the LDAP user
...@@ -62,10 +68,16 @@ module QA ...@@ -62,10 +68,16 @@ module QA
let(:owner_user) { 'enguser1' } let(:owner_user) { 'enguser1' }
let(:sync_users) { ['ENG User 2', 'ENG User 3'] } let(:sync_users) { ['ENG User 2', 'ENG User 3'] }
let(:group_name) { 'Synched-engineering-group' }
before do before do
@created_users = create_users_via_api(ldap_users) created_users = create_users_via_api(ldap_users)
group = create_group_and_add_user_via_api(owner_user, 'Synched-engineering-group', Resource::Members::AccessLevel::OWNER)
signin_and_visit_group_as_user(owner_user, group) group.add_member(created_users[owner_user], Resource::Members::AccessLevel::OWNER)
signin_as_user(owner_user)
group.visit!
Page::Group::Menu.perform(&:go_to_ldap_sync_settings) Page::Group::Menu.perform(&:go_to_ldap_sync_settings)
...@@ -113,12 +125,16 @@ module QA ...@@ -113,12 +125,16 @@ module QA
let(:owner_user) { 'hruser1' } let(:owner_user) { 'hruser1' }
let(:sync_users) { ['HR User 2', 'HR User 3'] } let(:sync_users) { ['HR User 2', 'HR User 3'] }
let(:group_name) { 'Synched-human-resources-group' }
before do before do
@created_users = create_users_via_api(ldap_users) created_users = create_users_via_api(ldap_users)
group.add_member(created_users[owner_user], Resource::Members::AccessLevel::OWNER)
group = create_group_and_add_user_via_api(owner_user, 'Synched-human-resources-group', Resource::Members::AccessLevel::OWNER) signin_as_user(owner_user)
signin_and_visit_group_as_user(owner_user, group) group.visit!
Page::Group::Menu.perform(&:go_to_ldap_sync_settings) Page::Group::Menu.perform(&:go_to_ldap_sync_settings)
...@@ -160,23 +176,23 @@ module QA ...@@ -160,23 +176,23 @@ module QA
group group
end end
def signin_and_visit_group_as_user(user_name, group) def signin_as_user(user_name)
user = Struct.new(:ldap_username, :ldap_password).new(user_name, 'password') user = Struct.new(:ldap_username, :ldap_password).new(user_name, 'password')
Runtime::Browser.visit(:gitlab, Page::Main::Login) Runtime::Browser.visit(:gitlab, Page::Main::Login)
Page::Main::Login.perform do |login_page| Page::Main::Login.perform do |login_page|
login_page.sign_in_using_ldap_credentials(user: user) login_page.sign_in_using_ldap_credentials(user: user)
end end
group.visit!
end end
def verify_users_synced(expected_users) def verify_users_synced(expected_users)
EE::Page::Group::Members.perform do |members| EE::Page::Group::Members.perform do |members|
members.click_sync_now members.click_sync_now
users_synchronised = members.retry_until(reload: true) do users_synchronised = members.retry_until(reload: true) do
expected_users.map { |user| members.has_content?(user) }.all? expected_users.map { |user| members.has_content?(user) }.all?
end end
expect(users_synchronised).to be_truthy expect(users_synchronised).to be_truthy
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