diff options
Diffstat (limited to 'spec/features/projects/settings/user_manages_project_members_spec.rb')
-rw-r--r-- | spec/features/projects/settings/user_manages_project_members_spec.rb | 134 |
1 files changed, 99 insertions, 35 deletions
diff --git a/spec/features/projects/settings/user_manages_project_members_spec.rb b/spec/features/projects/settings/user_manages_project_members_spec.rb index 726b8fb6840..0d22da34b91 100644 --- a/spec/features/projects/settings/user_manages_project_members_spec.rb +++ b/spec/features/projects/settings/user_manages_project_members_spec.rb @@ -3,6 +3,9 @@ require 'spec_helper' RSpec.describe 'Projects > Settings > User manages project members' do + include Spec::Support::Helpers::Features::MembersHelpers + include Select2Helper + let(:group) { create(:group, name: 'OpenSource') } let(:project) { create(:project) } let(:project2) { create(:project) } @@ -16,62 +19,123 @@ RSpec.describe 'Projects > Settings > User manages project members' do sign_in(user) end - it 'cancels a team member', :js do - visit(project_project_members_path(project)) + context 'when `vue_project_members_list` feature flag is enabled' do + it 'cancels a team member', :js do + visit(project_project_members_path(project)) + + page.within find_member_row(user_dmitriy) do + click_button 'Remove member' + end + + page.within('[role="dialog"]') do + expect(page).to have_unchecked_field 'Also unassign this user from related issues and merge requests' + click_button('Remove member') + end + + visit(project_project_members_path(project)) + + expect(members_table).not_to have_content(user_dmitriy.name) + expect(members_table).not_to have_content(user_dmitriy.username) + end + + it 'imports a team from another project', :js do + stub_feature_flags(invite_members_group_modal: false) + + project2.add_maintainer(user) + project2.add_reporter(user_mike) + + visit(project_project_members_path(project)) - project_member = project.project_members.find_by(user_id: user_dmitriy.id) + page.within('.invite-users-form') do + click_link('Import') + end - page.within("#project_member_#{project_member.id}") do - # Open modal - click_on('Remove user from project') + select2(project2.id, from: '#source_project_id') + click_button('Import project members') + + expect(find_member_row(user_mike)).to have_content('Reporter') end - expect(page).to have_unchecked_field 'Also unassign this user from related issues and merge requests' + it 'shows all members of project shared group', :js do + group.add_owner(user) + group.add_developer(user_dmitriy) + + share_link = project.project_group_links.new(group_access: Gitlab::Access::MAINTAINER) + share_link.group_id = group.id + share_link.save! - click_on('Remove member') + visit(project_project_members_path(project)) - visit(project_project_members_path(project)) + click_link 'Groups' - expect(page).not_to have_content(user_dmitriy.name) - expect(page).not_to have_content(user_dmitriy.username) + expect(find_group_row(group)).to have_content('Maintainer') + end end - it 'imports a team from another project' do - project2.add_maintainer(user) - project2.add_reporter(user_mike) + context 'when `vue_project_members_list` feature flag is disabled' do + before do + stub_feature_flags(vue_project_members_list: false) + end + + it 'cancels a team member', :js do + visit(project_project_members_path(project)) + + project_member = project.project_members.find_by(user_id: user_dmitriy.id) + + page.within("#project_member_#{project_member.id}") do + # Open modal + click_on('Remove user from project') + end + + expect(page).to have_unchecked_field 'Also unassign this user from related issues and merge requests' + + click_on('Remove member') - visit(project_project_members_path(project)) + visit(project_project_members_path(project)) - page.within('.invite-users-form') do - click_link('Import') + expect(page).not_to have_content(user_dmitriy.name) + expect(page).not_to have_content(user_dmitriy.username) end - select(project2.full_name, from: 'source_project_id') - click_button('Import') + it 'imports a team from another project' do + stub_feature_flags(invite_members_group_modal: false) - project_member = project.project_members.find_by(user_id: user_mike.id) + project2.add_maintainer(user) + project2.add_reporter(user_mike) - page.within("#project_member_#{project_member.id}") do - expect(page).to have_content('Mike') - expect(page).to have_content('Reporter') + visit(project_project_members_path(project)) + + page.within('.invite-users-form') do + click_link('Import') + end + + select(project2.full_name, from: 'source_project_id') + click_button('Import') + + project_member = project.project_members.find_by(user_id: user_mike.id) + + page.within("#project_member_#{project_member.id}") do + expect(page).to have_content('Mike') + expect(page).to have_content('Reporter') + end end - end - it 'shows all members of project shared group', :js do - group.add_owner(user) - group.add_developer(user_dmitriy) + it 'shows all members of project shared group', :js do + group.add_owner(user) + group.add_developer(user_dmitriy) - share_link = project.project_group_links.new(group_access: Gitlab::Access::MAINTAINER) - share_link.group_id = group.id - share_link.save! + share_link = project.project_group_links.new(group_access: Gitlab::Access::MAINTAINER) + share_link.group_id = group.id + share_link.save! - visit(project_project_members_path(project)) + visit(project_project_members_path(project)) - click_link 'Groups' + click_link 'Groups' - page.within('[data-testid="project-member-groups"]') do - expect(page).to have_content('OpenSource') - expect(first('.group_member')).to have_content('Maintainer') + page.within('[data-testid="project-member-groups"]') do + expect(page).to have_content('OpenSource') + expect(first('.group_member')).to have_content('Maintainer') + end end end end |