Commit 5e37b060 authored by Lin Jen-Shin's avatar Lin Jen-Shin

Do not allow maintainer to push to maintain 404

parent fe8f24a5
...@@ -10,7 +10,8 @@ RSpec.describe Projects::MergeRequestsController do ...@@ -10,7 +10,8 @@ RSpec.describe Projects::MergeRequestsController do
let_it_be_with_reload(:project_public_with_private_builds) { create(:project, :repository, :public, :builds_private) } let_it_be_with_reload(:project_public_with_private_builds) { create(:project, :repository, :public, :builds_private) }
let(:user) { project.owner } let(:user) { project.owner }
let(:merge_request) { create(:merge_request_with_diffs, target_project: project, source_project: project) } let(:merge_request) { create(:merge_request_with_diffs, target_project: project, source_project: merge_request_source_project, allow_maintainer_to_push: false) }
let(:merge_request_source_project) { project }
before do before do
sign_in(user) sign_in(user)
...@@ -2073,8 +2074,6 @@ RSpec.describe Projects::MergeRequestsController do ...@@ -2073,8 +2074,6 @@ RSpec.describe Projects::MergeRequestsController do
end end
describe 'POST #rebase' do describe 'POST #rebase' do
let(:viewer) { user }
def post_rebase def post_rebase
post :rebase, params: { namespace_id: project.namespace, project_id: project, id: merge_request } post :rebase, params: { namespace_id: project.namespace, project_id: project, id: merge_request }
end end
...@@ -2085,7 +2084,7 @@ RSpec.describe Projects::MergeRequestsController do ...@@ -2085,7 +2084,7 @@ RSpec.describe Projects::MergeRequestsController do
context 'successfully' do context 'successfully' do
it 'enqeues a RebaseWorker' do it 'enqeues a RebaseWorker' do
expect_rebase_worker_for(viewer) expect_rebase_worker_for(user)
post_rebase post_rebase
...@@ -2108,17 +2107,17 @@ RSpec.describe Projects::MergeRequestsController do ...@@ -2108,17 +2107,17 @@ RSpec.describe Projects::MergeRequestsController do
context 'with a forked project' do context 'with a forked project' do
let(:forked_project) { fork_project(project, fork_owner, repository: true) } let(:forked_project) { fork_project(project, fork_owner, repository: true) }
let(:fork_owner) { create(:user) } let(:fork_owner) { create(:user) }
let(:merge_request_source_project) { forked_project }
context 'user cannot push to source branch' do
before do before do
project.add_developer(fork_owner) project.add_developer(fork_owner)
merge_request.update!(source_project: forked_project)
forked_project.add_reporter(user) forked_project.add_reporter(user)
end end
context 'user cannot push to source branch' do
it 'returns 404' do it 'returns 404' do
expect_rebase_worker_for(viewer).never expect_rebase_worker_for(user).never
post_rebase post_rebase
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment