summaryrefslogtreecommitdiff
path: root/spec/features/groups/members/user_requests_access_spec.rb
diff options
context:
space:
mode:
Diffstat (limited to 'spec/features/groups/members/user_requests_access_spec.rb')
-rw-r--r--spec/features/groups/members/user_requests_access_spec.rb71
1 files changed, 0 insertions, 71 deletions
diff --git a/spec/features/groups/members/user_requests_access_spec.rb b/spec/features/groups/members/user_requests_access_spec.rb
deleted file mode 100644
index e4b5ea91bd3..00000000000
--- a/spec/features/groups/members/user_requests_access_spec.rb
+++ /dev/null
@@ -1,71 +0,0 @@
-require 'spec_helper'
-
-feature 'Groups > Members > User requests access', feature: true do
- let(:user) { create(:user) }
- let(:owner) { create(:user) }
- let(:group) { create(:group, :public, :access_requestable) }
- let!(:project) { create(:project, :private, namespace: group) }
-
- background do
- group.add_owner(owner)
- login_as(user)
- visit group_path(group)
- end
-
- scenario 'request access feature is disabled' do
- group.update_attributes(request_access_enabled: false)
- visit group_path(group)
-
- expect(page).not_to have_content 'Request Access'
- end
-
- scenario 'user can request access to a group' do
- perform_enqueued_jobs { click_link 'Request Access' }
-
- expect(ActionMailer::Base.deliveries.last.to).to eq [owner.notification_email]
- expect(ActionMailer::Base.deliveries.last.subject).to match "Request to join the #{group.name} group"
-
- expect(group.requesters.exists?(user_id: user)).to be_truthy
- expect(page).to have_content 'Your request for access has been queued for review.'
-
- expect(page).to have_content 'Withdraw Access Request'
- expect(page).not_to have_content 'Leave group'
- end
-
- scenario 'user does not see private projects' do
- perform_enqueued_jobs { click_link 'Request Access' }
-
- expect(page).not_to have_content project.name
- end
-
- scenario 'user does not see group in the Dashboard > Groups page' do
- perform_enqueued_jobs { click_link 'Request Access' }
-
- visit dashboard_groups_path
-
- expect(page).not_to have_content group.name
- end
-
- scenario 'user is not listed in the group members page' do
- click_link 'Request Access'
-
- expect(group.requesters.exists?(user_id: user)).to be_truthy
-
- click_link 'Members'
-
- page.within('.content') do
- expect(page).not_to have_content(user.name)
- end
- end
-
- scenario 'user can withdraw its request for access' do
- click_link 'Request Access'
-
- expect(group.requesters.exists?(user_id: user)).to be_truthy
-
- click_link 'Withdraw Access Request'
-
- expect(group.requesters.exists?(user_id: user)).to be_falsey
- expect(page).to have_content 'Your access request to the group has been withdrawn.'
- end
-end