2019-10-12 21:52:04 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2018-03-27 19:54:05 +05:30
|
|
|
require 'spec_helper'
|
|
|
|
|
2020-06-23 00:09:42 +05:30
|
|
|
RSpec.describe 'create a merge request, allowing commits from members who can merge to the target branch', :js do
|
2018-03-27 19:54:05 +05:30
|
|
|
include ProjectForksHelper
|
|
|
|
let(:user) { create(:user) }
|
|
|
|
let(:target_project) { create(:project, :public, :repository) }
|
|
|
|
let(:source_project) { fork_project(target_project, user, repository: true, namespace: user.namespace) }
|
|
|
|
|
|
|
|
def visit_new_merge_request
|
|
|
|
visit project_new_merge_request_path(
|
|
|
|
source_project,
|
|
|
|
merge_request: {
|
|
|
|
source_project_id: source_project.id,
|
|
|
|
target_project_id: target_project.id,
|
|
|
|
source_branch: 'fix',
|
|
|
|
target_branch: 'master'
|
|
|
|
})
|
|
|
|
end
|
|
|
|
|
|
|
|
before do
|
|
|
|
sign_in(user)
|
|
|
|
end
|
|
|
|
|
2019-12-26 22:10:19 +05:30
|
|
|
it 'allows setting possible', :sidekiq_might_not_need_inline do
|
2018-03-27 19:54:05 +05:30
|
|
|
visit_new_merge_request
|
|
|
|
|
2018-11-08 19:23:39 +05:30
|
|
|
check 'Allow commits from members who can merge to the target branch'
|
2018-03-27 19:54:05 +05:30
|
|
|
|
2021-04-29 21:17:54 +05:30
|
|
|
click_button 'Create merge request'
|
2018-03-27 19:54:05 +05:30
|
|
|
|
|
|
|
wait_for_requests
|
|
|
|
|
2021-09-04 01:27:46 +05:30
|
|
|
expect(page).to have_content('Members who can merge are allowed to add commits.')
|
2018-03-27 19:54:05 +05:30
|
|
|
end
|
|
|
|
|
2019-12-26 22:10:19 +05:30
|
|
|
it 'shows a message when one of the projects is private', :sidekiq_might_not_need_inline do
|
2018-03-27 19:54:05 +05:30
|
|
|
source_project.update!(visibility_level: Gitlab::VisibilityLevel::PRIVATE)
|
|
|
|
|
|
|
|
visit_new_merge_request
|
|
|
|
|
|
|
|
expect(page).to have_content('Not available for private projects')
|
|
|
|
end
|
|
|
|
|
2019-12-26 22:10:19 +05:30
|
|
|
it 'shows a message when the source branch is protected', :sidekiq_might_not_need_inline do
|
2018-03-27 19:54:05 +05:30
|
|
|
create(:protected_branch, project: source_project, name: 'fix')
|
|
|
|
|
|
|
|
visit_new_merge_request
|
|
|
|
|
|
|
|
expect(page).to have_content('Not available for protected branches')
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when the merge request is being created within the same project' do
|
|
|
|
let(:source_project) { target_project }
|
|
|
|
|
|
|
|
it 'hides the checkbox if the merge request is being created within the same project' do
|
|
|
|
target_project.add_developer(user)
|
|
|
|
|
|
|
|
visit_new_merge_request
|
|
|
|
|
2021-09-04 01:27:46 +05:30
|
|
|
expect(page).not_to have_content('The fork project allows commits from members who can write to the target branch.')
|
2018-03-27 19:54:05 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-11-08 19:23:39 +05:30
|
|
|
context 'when a member who can merge tries to edit the option' do
|
|
|
|
let(:member) { create(:user) }
|
2018-03-27 19:54:05 +05:30
|
|
|
let(:merge_request) do
|
|
|
|
create(:merge_request,
|
|
|
|
source_project: source_project,
|
|
|
|
target_project: target_project,
|
|
|
|
source_branch: 'fixes')
|
|
|
|
end
|
|
|
|
|
|
|
|
before do
|
2018-11-18 11:00:15 +05:30
|
|
|
target_project.add_maintainer(member)
|
2018-03-27 19:54:05 +05:30
|
|
|
|
2018-11-08 19:23:39 +05:30
|
|
|
sign_in(member)
|
2018-03-27 19:54:05 +05:30
|
|
|
end
|
|
|
|
|
2019-07-07 11:18:12 +05:30
|
|
|
it 'hides the option from members' do
|
2018-03-27 19:54:05 +05:30
|
|
|
visit edit_project_merge_request_path(target_project, merge_request)
|
|
|
|
|
2021-09-04 01:27:46 +05:30
|
|
|
expect(page).not_to have_content('The fork project allows commits from members who can write to the target branch.')
|
2018-03-27 19:54:05 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|