gitlab-org--gitlab-foss/spec/features/projects/members/user_requests_access_spec.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

87 lines
2.5 KiB
Ruby
Raw Permalink Normal View History

# frozen_string_literal: true
require 'spec_helper'
RSpec.describe 'Projects > Members > User requests access', :js do
include Spec::Support::Helpers::ModalHelpers
let_it_be(:user) { create(:user) }
let_it_be(:maintainer) { create(:user) }
let_it_be(:project) { create(:project, :public, :repository) }
let(:owner) { project.first_owner }
2018-07-05 02:32:05 -04:00
before do
sign_in(user)
project.add_maintainer(maintainer)
visit project_path(project)
end
2018-07-05 02:32:05 -04:00
it 'request access feature is disabled' do
project.update!(request_access_enabled: false)
visit project_path(project)
expect(page).not_to have_content 'Request Access'
end
2018-07-05 02:32:05 -04:00
it 'user can request access to a project' do
perform_enqueued_jobs { click_link 'Request Access' }
expect(ActionMailer::Base.deliveries.map(&:to)).to match_array([[owner.notification_email_or_default], [maintainer.notification_email_or_default]])
expect(ActionMailer::Base.deliveries.last.subject).to eq "Request to join the #{project.full_name} project"
expect(project.requesters.exists?(user_id: user)).to be_truthy
expect(page).to have_content 'Withdraw Access Request'
expect(page).not_to have_content 'Leave Project'
end
context 'code access is restricted' do
2018-07-05 02:32:05 -04:00
it 'user can request access' do
project.project_feature.update!(repository_access_level: ProjectFeature::PRIVATE,
builds_access_level: ProjectFeature::PRIVATE,
merge_requests_access_level: ProjectFeature::PRIVATE)
visit project_path(project)
expect(page).to have_content 'Request Access'
end
end
2018-07-05 02:32:05 -04:00
it 'user is not listed in the project members page' do
click_link 'Request Access'
expect(project.requesters.exists?(user_id: user)).to be_truthy
click_link 'Project information'
2017-08-18 07:07:10 -04:00
page.within('.nav-sidebar') do
click_link('Members')
end
page.within('.content') do
expect(page).not_to have_content(user.name)
end
end
2018-07-05 02:32:05 -04:00
it 'user can withdraw its request for access' do
click_link 'Request Access'
expect(project.requesters.exists?(user_id: user)).to be_truthy
accept_gl_confirm { click_link 'Withdraw Access Request' }
expect(page).not_to have_content 'Withdraw Access Request'
expect(page).to have_content 'Request Access'
end
def open_project_settings_menu
2017-03-07 21:43:08 -05:00
page.within('.layout-nav .nav-links') do
click_link('Settings')
end
page.within('.sub-nav') do
2017-03-07 21:43:08 -05:00
click_link('Members')
end
end
end