Commit e1e9083e authored by Rémy Coutable's avatar Rémy Coutable

Merge branch 'enable_invite_members_group_modal_tests' into 'master'

Enable invite members modal tests [RUN ALL RSPEC]

See merge request gitlab-org/gitlab!60178
parents 9efb5c2f 168d6bb0
...@@ -5,6 +5,7 @@ require 'spec_helper' ...@@ -5,6 +5,7 @@ require 'spec_helper'
RSpec.describe 'Admin Groups' do RSpec.describe 'Admin Groups' do
include Select2Helper include Select2Helper
include Spec::Support::Helpers::Features::MembersHelpers include Spec::Support::Helpers::Features::MembersHelpers
include Spec::Support::Helpers::Features::InviteMembersModalHelper
let(:internal) { Gitlab::VisibilityLevel::INTERNAL } let(:internal) { Gitlab::VisibilityLevel::INTERNAL }
...@@ -202,6 +203,7 @@ RSpec.describe 'Admin Groups' do ...@@ -202,6 +203,7 @@ RSpec.describe 'Admin Groups' do
select2(Gitlab::Access::REPORTER, from: '#access_level') select2(Gitlab::Access::REPORTER, from: '#access_level')
end end
click_button "Add users to group" click_button "Add users to group"
page.within ".group-users-list" do page.within ".group-users-list" do
expect(page).to have_content(user.name) expect(page).to have_content(user.name)
expect(page).to have_content('Reporter') expect(page).to have_content('Reporter')
...@@ -220,19 +222,13 @@ RSpec.describe 'Admin Groups' do ...@@ -220,19 +222,13 @@ RSpec.describe 'Admin Groups' do
describe 'add admin himself to a group' do describe 'add admin himself to a group' do
before do before do
stub_feature_flags(invite_members_group_modal: false)
group.add_user(:user, Gitlab::Access::OWNER) group.add_user(:user, Gitlab::Access::OWNER)
end end
it 'adds admin a to a group as developer', :js do it 'adds admin a to a group as developer', :js do
visit group_group_members_path(group) visit group_group_members_path(group)
page.within '.invite-users-form' do invite_member(current_user.name, role: 'Developer')
select2(current_user.id, from: '#user_ids', multiple: true)
select 'Developer', from: 'access_level'
end
click_button 'Invite'
page.within members_table do page.within members_table do
expect(page).to have_content(current_user.name) expect(page).to have_content(current_user.name)
......
...@@ -4,6 +4,7 @@ require 'spec_helper' ...@@ -4,6 +4,7 @@ require 'spec_helper'
RSpec.describe "Admin::Projects" do RSpec.describe "Admin::Projects" do
include Spec::Support::Helpers::Features::MembersHelpers include Spec::Support::Helpers::Features::MembersHelpers
include Spec::Support::Helpers::Features::InviteMembersModalHelper
include Select2Helper include Select2Helper
let(:user) { create :user } let(:user) { create :user }
...@@ -95,22 +96,28 @@ RSpec.describe "Admin::Projects" do ...@@ -95,22 +96,28 @@ RSpec.describe "Admin::Projects" do
describe 'admin adds themselves to the project', :js do describe 'admin adds themselves to the project', :js do
before do before do
project.add_maintainer(user) project.add_maintainer(user)
stub_feature_flags(invite_members_group_modal: false)
end end
it 'adds admin to the project as developer' do it 'adds admin to the project as developer' do
visit project_project_members_path(project) visit project_project_members_path(project)
page.within '.invite-users-form' do invite_member(current_user.name, role: 'Developer')
select2(current_user.id, from: '#user_ids', multiple: true)
select 'Developer', from: 'access_level' expect(find_member_row(current_user)).to have_content('Developer')
end end
click_button 'Invite' context 'with the invite_members_group_modal feature flag disabled' do
it 'adds admin to the project as developer' do
stub_feature_flags(invite_members_group_modal: false)
visit project_project_members_path(project)
add_member_using_form(current_user.id, role: 'Developer')
expect(find_member_row(current_user)).to have_content('Developer') expect(find_member_row(current_user)).to have_content('Developer')
end end
end end
end
describe 'admin removes themselves from the project', :js do describe 'admin removes themselves from the project', :js do
before do before do
...@@ -134,4 +141,19 @@ RSpec.describe "Admin::Projects" do ...@@ -134,4 +141,19 @@ RSpec.describe "Admin::Projects" do
expect(current_path).to match dashboard_projects_path expect(current_path).to match dashboard_projects_path
end end
end end
# temporary method for the form until the :invite_members_group_modal feature flag is
# enabled: https://gitlab.com/gitlab-org/gitlab/-/issues/247208
def add_member_using_form(id, role: 'Developer')
page.within '.invite-users-form' do
select2(id, from: '#user_ids', multiple: true)
fill_in 'expires_at', with: 5.days.from_now.to_date
find_field('expires_at').native.send_keys :enter
select(role, from: "access_level")
click_on 'Invite'
end
end
end end
...@@ -5,13 +5,13 @@ require 'spec_helper' ...@@ -5,13 +5,13 @@ require 'spec_helper'
RSpec.describe 'Groups > Members > Manage members' do RSpec.describe 'Groups > Members > Manage members' do
include Select2Helper include Select2Helper
include Spec::Support::Helpers::Features::MembersHelpers include Spec::Support::Helpers::Features::MembersHelpers
include Spec::Support::Helpers::Features::InviteMembersModalHelper
let(:user1) { create(:user, name: 'John Doe') } let(:user1) { create(:user, name: 'John Doe') }
let(:user2) { create(:user, name: 'Mary Jane') } let(:user2) { create(:user, name: 'Mary Jane') }
let(:group) { create(:group) } let(:group) { create(:group) }
before do before do
stub_feature_flags(invite_members_group_modal: false)
sign_in(user1) sign_in(user1)
end end
...@@ -27,15 +27,15 @@ RSpec.describe 'Groups > Members > Manage members' do ...@@ -27,15 +27,15 @@ RSpec.describe 'Groups > Members > Manage members' do
end end
context 'when Invite Members modal is enabled' do context 'when Invite Members modal is enabled' do
before do
stub_feature_flags(invite_members_group_modal: true)
end
it_behaves_like 'includes the correct Invite link', '.js-invite-members-trigger', '.invite-users-form' it_behaves_like 'includes the correct Invite link', '.js-invite-members-trigger', '.invite-users-form'
it_behaves_like 'includes the correct Invite link', '.js-invite-group-trigger', '.invite-group-form' it_behaves_like 'includes the correct Invite link', '.js-invite-group-trigger', '.invite-group-form'
end end
context 'when Invite Members modal is disabled' do context 'when Invite Members modal is disabled' do
before do
stub_feature_flags(invite_members_group_modal: false)
end
it_behaves_like 'includes the correct Invite link', '.invite-users-form', '.js-invite-members-trigger' it_behaves_like 'includes the correct Invite link', '.invite-users-form', '.js-invite-members-trigger'
it_behaves_like 'includes the correct Invite link', '.invite-group-form', '.js-invite-group-trigger' it_behaves_like 'includes the correct Invite link', '.invite-group-form', '.js-invite-group-trigger'
end end
...@@ -59,7 +59,7 @@ RSpec.describe 'Groups > Members > Manage members' do ...@@ -59,7 +59,7 @@ RSpec.describe 'Groups > Members > Manage members' do
visit group_group_members_path(group) visit group_group_members_path(group)
add_user(user2.id, 'Reporter') invite_member(user2.name, role: 'Reporter')
page.within(second_row) do page.within(second_row) do
expect(page).to have_content(user2.name) expect(page).to have_content(user2.name)
...@@ -67,6 +67,30 @@ RSpec.describe 'Groups > Members > Manage members' do ...@@ -67,6 +67,30 @@ RSpec.describe 'Groups > Members > Manage members' do
end end
end end
it 'do not disclose email addresses', :js do
group.add_owner(user1)
create(:user, email: 'undisclosed_email@gitlab.com', name: "Jane 'invisible' Doe")
visit group_group_members_path(group)
click_on 'Invite members'
fill_in 'Select members or type email addresses', with: '@gitlab.com'
wait_for_requests
expect(page).to have_content('No matches found')
fill_in 'Select members or type email addresses', with: 'undisclosed_email@gitlab.com'
wait_for_requests
expect(page).to have_content("Jane 'invisible' Doe")
end
context 'when Invite Members modal is disabled' do
before do
stub_feature_flags(invite_members_group_modal: false)
end
it 'do not disclose email addresses', :js do it 'do not disclose email addresses', :js do
group.add_owner(user1) group.add_owner(user1)
create(:user, email: 'undisclosed_email@gitlab.com', name: "Jane 'invisible' Doe") create(:user, email: 'undisclosed_email@gitlab.com', name: "Jane 'invisible' Doe")
...@@ -87,6 +111,7 @@ RSpec.describe 'Groups > Members > Manage members' do ...@@ -87,6 +111,7 @@ RSpec.describe 'Groups > Members > Manage members' do
expect(page).to have_content("Jane 'invisible' Doe") expect(page).to have_content("Jane 'invisible' Doe")
end end
end
it 'remove user from group', :js do it 'remove user from group', :js do
group.add_owner(user1) group.add_owner(user1)
...@@ -115,7 +140,7 @@ RSpec.describe 'Groups > Members > Manage members' do ...@@ -115,7 +140,7 @@ RSpec.describe 'Groups > Members > Manage members' do
visit group_group_members_path(group) visit group_group_members_path(group)
add_user(user1.id, 'Reporter') invite_member(user1.name, role: 'Reporter')
page.within(first_row) do page.within(first_row) do
expect(page).to have_content(user1.name) expect(page).to have_content(user1.name)
...@@ -128,7 +153,7 @@ RSpec.describe 'Groups > Members > Manage members' do ...@@ -128,7 +153,7 @@ RSpec.describe 'Groups > Members > Manage members' do
visit group_group_members_path(group) visit group_group_members_path(group)
add_user('test@example.com', 'Reporter') invite_member('test@example.com', role: 'Reporter')
expect(page).to have_link 'Invited' expect(page).to have_link 'Invited'
click_link 'Invited' click_link 'Invited'
...@@ -148,6 +173,8 @@ RSpec.describe 'Groups > Members > Manage members' do ...@@ -148,6 +173,8 @@ RSpec.describe 'Groups > Members > Manage members' do
expect(page).not_to have_selector '.invite-users-form' expect(page).not_to have_selector '.invite-users-form'
expect(page).not_to have_selector '.invite-group-form' expect(page).not_to have_selector '.invite-group-form'
expect(page).not_to have_selector '.js-invite-members-modal'
expect(page).not_to have_selector '.js-invite-group-modal'
page.within(second_row) do page.within(second_row) do
# Can not modify user2 role # Can not modify user2 role
...@@ -157,12 +184,4 @@ RSpec.describe 'Groups > Members > Manage members' do ...@@ -157,12 +184,4 @@ RSpec.describe 'Groups > Members > Manage members' do
expect(page).not_to have_selector 'button[title="Remove member"]' expect(page).not_to have_selector 'button[title="Remove member"]'
end end
end end
def add_user(id, role)
page.within ".invite-users-form" do
select2(id, from: "#user_ids", multiple: true)
select(role, from: "access_level")
click_button "Invite"
end
end
end end
...@@ -3,8 +3,8 @@ ...@@ -3,8 +3,8 @@
require 'spec_helper' require 'spec_helper'
RSpec.describe 'Groups > Members > Owner adds member with expiration date', :js do RSpec.describe 'Groups > Members > Owner adds member with expiration date', :js do
include Select2Helper
include Spec::Support::Helpers::Features::MembersHelpers include Spec::Support::Helpers::Features::MembersHelpers
include Spec::Support::Helpers::Features::InviteMembersModalHelper
let_it_be(:user1) { create(:user, name: 'John Doe') } let_it_be(:user1) { create(:user, name: 'John Doe') }
let_it_be(:group) { create(:group) } let_it_be(:group) { create(:group) }
...@@ -12,7 +12,6 @@ RSpec.describe 'Groups > Members > Owner adds member with expiration date', :js ...@@ -12,7 +12,6 @@ RSpec.describe 'Groups > Members > Owner adds member with expiration date', :js
let(:new_member) { create(:user, name: 'Mary Jane') } let(:new_member) { create(:user, name: 'Mary Jane') }
before do before do
stub_feature_flags(invite_members_group_modal: false)
group.add_owner(user1) group.add_owner(user1)
sign_in(user1) sign_in(user1)
end end
...@@ -20,14 +19,7 @@ RSpec.describe 'Groups > Members > Owner adds member with expiration date', :js ...@@ -20,14 +19,7 @@ RSpec.describe 'Groups > Members > Owner adds member with expiration date', :js
it 'expiration date is displayed in the members list' do it 'expiration date is displayed in the members list' do
visit group_group_members_path(group) visit group_group_members_path(group)
page.within invite_users_form do invite_member(new_member.name, role: 'Guest', expires_at: 5.days.from_now.to_date)
select2(new_member.id, from: '#user_ids', multiple: true)
fill_in 'expires_at', with: 5.days.from_now.to_date
find_field('expires_at').native.send_keys :enter
click_on 'Invite'
end
page.within second_row do page.within second_row do
expect(page).to have_content(/in \d days/) expect(page).to have_content(/in \d days/)
......
...@@ -3,8 +3,8 @@ ...@@ -3,8 +3,8 @@
require 'spec_helper' require 'spec_helper'
RSpec.describe 'Project members list', :js do RSpec.describe 'Project members list', :js do
include Select2Helper
include Spec::Support::Helpers::Features::MembersHelpers include Spec::Support::Helpers::Features::MembersHelpers
include Spec::Support::Helpers::Features::InviteMembersModalHelper
let(:user1) { create(:user, name: 'John Doe') } let(:user1) { create(:user, name: 'John Doe') }
let(:user2) { create(:user, name: 'Mary Jane') } let(:user2) { create(:user, name: 'Mary Jane') }
...@@ -12,8 +12,6 @@ RSpec.describe 'Project members list', :js do ...@@ -12,8 +12,6 @@ RSpec.describe 'Project members list', :js do
let(:project) { create(:project, :internal, namespace: group) } let(:project) { create(:project, :internal, namespace: group) }
before do before do
stub_feature_flags(invite_members_group_modal: true)
sign_in(user1) sign_in(user1)
group.add_owner(user1) group.add_owner(user1)
end end
...@@ -52,7 +50,7 @@ RSpec.describe 'Project members list', :js do ...@@ -52,7 +50,7 @@ RSpec.describe 'Project members list', :js do
it 'add user to project' do it 'add user to project' do
visit_members_page visit_members_page
add_user(user2.name, 'Reporter') invite_member(user2.name, role: 'Reporter')
page.within find_member_row(user2) do page.within find_member_row(user2) do
expect(page).to have_button('Reporter') expect(page).to have_button('Reporter')
...@@ -100,7 +98,7 @@ RSpec.describe 'Project members list', :js do ...@@ -100,7 +98,7 @@ RSpec.describe 'Project members list', :js do
it 'invite user to project' do it 'invite user to project' do
visit_members_page visit_members_page
add_user('test@example.com', 'Reporter') invite_member('test@example.com', role: 'Reporter')
click_link 'Invited' click_link 'Invited'
...@@ -171,25 +169,6 @@ RSpec.describe 'Project members list', :js do ...@@ -171,25 +169,6 @@ RSpec.describe 'Project members list', :js do
private private
def add_user(id, role)
click_on 'Invite members'
page.within '#invite-members-modal' do
fill_in 'Select members or type email addresses', with: id
wait_for_requests
click_button id
click_button 'Guest'
wait_for_requests
click_button role
click_button 'Invite'
end
page.refresh
end
def visit_members_page def visit_members_page
visit project_project_members_path(project) visit project_project_members_path(project)
end end
......
...@@ -3,9 +3,9 @@ ...@@ -3,9 +3,9 @@
require 'spec_helper' require 'spec_helper'
RSpec.describe 'Projects > Members > Maintainer adds member with expiration date', :js do RSpec.describe 'Projects > Members > Maintainer adds member with expiration date', :js do
include Select2Helper
include ActiveSupport::Testing::TimeHelpers include ActiveSupport::Testing::TimeHelpers
include Spec::Support::Helpers::Features::MembersHelpers include Spec::Support::Helpers::Features::MembersHelpers
include Spec::Support::Helpers::Features::InviteMembersModalHelper
let_it_be(:maintainer) { create(:user) } let_it_be(:maintainer) { create(:user) }
let_it_be(:project) { create(:project) } let_it_be(:project) { create(:project) }
...@@ -20,18 +20,9 @@ RSpec.describe 'Projects > Members > Maintainer adds member with expiration date ...@@ -20,18 +20,9 @@ RSpec.describe 'Projects > Members > Maintainer adds member with expiration date
end end
it 'expiration date is displayed in the members list' do it 'expiration date is displayed in the members list' do
stub_feature_flags(invite_members_group_modal: false)
visit project_project_members_path(project) visit project_project_members_path(project)
page.within '.invite-users-form' do invite_member(new_member.name, role: 'Guest', expires_at: 5.days.from_now.to_date)
select2(new_member.id, from: '#user_ids', multiple: true)
fill_in 'expires_at', with: 5.days.from_now.to_date
find_field('expires_at').native.send_keys :enter
click_on 'Invite'
end
page.within find_member_row(new_member) do page.within find_member_row(new_member) do
expect(page).to have_content(/in \d days/) expect(page).to have_content(/in \d days/)
......
...@@ -150,8 +150,6 @@ RSpec.describe InviteMembersHelper do ...@@ -150,8 +150,6 @@ RSpec.describe InviteMembersHelper do
end end
it 'returns false' do it 'returns false' do
stub_feature_flags(invite_members_group_modal: false)
expect(helper.can_invite_members_for_group?(group)).to eq false expect(helper.can_invite_members_for_group?(group)).to eq false
expect(helper).not_to have_received(:can?) expect(helper).not_to have_received(:can?)
end end
......
# frozen_string_literal: true
module Spec
module Support
module Helpers
module Features
module InviteMembersModalHelper
def invite_member(name, role: 'Guest', expires_at: nil)
click_on 'Invite members'
page.within '#invite-members-modal' do
fill_in 'Select members or type email addresses', with: name
wait_for_requests
click_button name
fill_in 'YYYY-MM-DD', with: expires_at.try(:strftime, '%Y-%m-%d')
unless role == 'Guest'
click_button 'Guest'
wait_for_requests
click_button role
end
click_button 'Invite'
end
page.refresh
end
end
end
end
end
end
...@@ -27,10 +27,6 @@ module Spec ...@@ -27,10 +27,6 @@ module Spec
all_rows[2] all_rows[2]
end end
def invite_users_form
page.find('[data-testid="invite-users-form"]')
end
def find_row(name) def find_row(name)
page.within(members_table) do page.within(members_table) do
page.find('tbody > tr', text: name) page.find('tbody > tr', text: name)
......
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