130 lines
4.0 KiB
Ruby
130 lines
4.0 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
shared_examples "protected branches > access control > CE" do
|
|
ProtectedRefAccess::HUMAN_ACCESS_LEVELS.each do |(access_type_id, access_type_name)|
|
|
it "allows creating protected branches that #{access_type_name} can push to" do
|
|
visit project_protected_branches_path(project)
|
|
|
|
set_protected_branch_name('master')
|
|
|
|
find(".js-allowed-to-merge").click
|
|
within('.rspec-allowed-to-merge-dropdown') do
|
|
expect(first("li")).to have_content("Roles")
|
|
find(:link, 'No one').click
|
|
end
|
|
|
|
within('.js-new-protected-branch') do
|
|
allowed_to_push_button = find(".js-allowed-to-push")
|
|
|
|
unless allowed_to_push_button.text == access_type_name
|
|
allowed_to_push_button.click
|
|
within(".dropdown.show .dropdown-menu") { click_on access_type_name }
|
|
end
|
|
end
|
|
|
|
click_on "Protect"
|
|
|
|
expect(ProtectedBranch.count).to eq(1)
|
|
expect(ProtectedBranch.last.push_access_levels.map(&:access_level)).to eq([access_type_id])
|
|
end
|
|
|
|
it "allows updating protected branches so that #{access_type_name} can push to them" do
|
|
visit project_protected_branches_path(project)
|
|
|
|
set_protected_branch_name('master')
|
|
|
|
find(".js-allowed-to-merge").click
|
|
within('.rspec-allowed-to-merge-dropdown') do
|
|
expect(first("li")).to have_content("Roles")
|
|
find(:link, 'No one').click
|
|
end
|
|
|
|
find(".js-allowed-to-push").click
|
|
within('.rspec-allowed-to-push-dropdown') do
|
|
expect(first("li")).to have_content("Roles")
|
|
find(:link, 'No one').click
|
|
end
|
|
|
|
click_on "Protect"
|
|
|
|
expect(ProtectedBranch.count).to eq(1)
|
|
|
|
within(".protected-branches-list") do
|
|
find(".js-allowed-to-push").click
|
|
|
|
within('.js-allowed-to-push-container') do
|
|
expect(first("li")).to have_content("Roles")
|
|
find(:link, access_type_name).click
|
|
end
|
|
end
|
|
|
|
wait_for_requests
|
|
|
|
expect(ProtectedBranch.last.push_access_levels.map(&:access_level)).to include(access_type_id)
|
|
end
|
|
end
|
|
|
|
ProtectedRefAccess::HUMAN_ACCESS_LEVELS.each do |(access_type_id, access_type_name)|
|
|
it "allows creating protected branches that #{access_type_name} can merge to" do
|
|
visit project_protected_branches_path(project)
|
|
|
|
set_protected_branch_name('master')
|
|
|
|
within('.js-new-protected-branch') do
|
|
allowed_to_merge_button = find(".js-allowed-to-merge")
|
|
|
|
unless allowed_to_merge_button.text == access_type_name
|
|
allowed_to_merge_button.click
|
|
within(".dropdown.show .dropdown-menu") { click_on access_type_name }
|
|
end
|
|
end
|
|
|
|
find(".js-allowed-to-push").click
|
|
within('.rspec-allowed-to-push-dropdown') do
|
|
expect(first("li")).to have_content("Roles")
|
|
find(:link, 'No one').click
|
|
end
|
|
|
|
click_on "Protect"
|
|
|
|
expect(ProtectedBranch.count).to eq(1)
|
|
expect(ProtectedBranch.last.merge_access_levels.map(&:access_level)).to eq([access_type_id])
|
|
end
|
|
|
|
it "allows updating protected branches so that #{access_type_name} can merge to them" do
|
|
visit project_protected_branches_path(project)
|
|
|
|
set_protected_branch_name('master')
|
|
|
|
find(".js-allowed-to-merge").click
|
|
within('.rspec-allowed-to-merge-dropdown') do
|
|
expect(first("li")).to have_content("Roles")
|
|
find(:link, 'No one').click
|
|
end
|
|
|
|
find(".js-allowed-to-push").click
|
|
within('.rspec-allowed-to-push-dropdown') do
|
|
expect(first("li")).to have_content("Roles")
|
|
find(:link, 'No one').click
|
|
end
|
|
|
|
click_on "Protect"
|
|
|
|
expect(ProtectedBranch.count).to eq(1)
|
|
|
|
within(".protected-branches-list") do
|
|
find(".js-allowed-to-merge").click
|
|
|
|
within('.js-allowed-to-merge-container') do
|
|
expect(first("li")).to have_content("Roles")
|
|
find(:link, access_type_name).click
|
|
end
|
|
end
|
|
|
|
wait_for_requests
|
|
|
|
expect(ProtectedBranch.last.merge_access_levels.map(&:access_level)).to include(access_type_id)
|
|
end
|
|
end
|
|
end
|