57 lines
1.5 KiB
Ruby
57 lines
1.5 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
RSpec.shared_examples 'Maintainer manages access requests' do
|
|
include Spec::Support::Helpers::Features::MembersHelpers
|
|
|
|
let(:user) { create(:user) }
|
|
let(:maintainer) { create(:user) }
|
|
|
|
before do
|
|
entity.request_access(user)
|
|
entity.respond_to?(:add_owner) ? entity.add_owner(maintainer) : entity.add_maintainer(maintainer)
|
|
sign_in(maintainer)
|
|
visit members_page_path
|
|
|
|
click_on 'Access requests'
|
|
end
|
|
|
|
it 'maintainer can see access requests', :js do
|
|
expect_visible_access_request(entity, user)
|
|
end
|
|
|
|
it 'maintainer can grant access', :js do
|
|
expect_visible_access_request(entity, user)
|
|
|
|
click_on 'Grant access'
|
|
|
|
expect_no_visible_access_request(entity, user)
|
|
|
|
page.within(members_table) do
|
|
expect(page).to have_content user.name
|
|
end
|
|
end
|
|
|
|
it 'maintainer can deny access', :js do
|
|
expect_visible_access_request(entity, user)
|
|
|
|
# Open modal
|
|
click_on 'Deny access'
|
|
|
|
expect(page).not_to have_field "Also unassign this user from related issues and merge requests"
|
|
|
|
click_on 'Deny access request'
|
|
|
|
expect_no_visible_access_request(entity, user)
|
|
expect(page).not_to have_content user.name
|
|
end
|
|
|
|
def expect_visible_access_request(entity, user)
|
|
expect(page).to have_content "Access requests 1"
|
|
|
|
expect(page).to have_content user.name
|
|
end
|
|
|
|
def expect_no_visible_access_request(entity, user)
|
|
expect(page).not_to have_content "Users requesting access to #{entity.name}"
|
|
end
|
|
end
|