Commit 570a583c authored by Peter Leitzen's avatar Peter Leitzen

Merge branch 'xanf-fix-404-on-import' into 'master'

Resolve "Importing project by user with developer rights results in 404"

See merge request gitlab-org/gitlab!35667
parents a5267967 b2ce4407
...@@ -5,7 +5,8 @@ class Projects::ImportsController < Projects::ApplicationController ...@@ -5,7 +5,8 @@ class Projects::ImportsController < Projects::ApplicationController
include ImportUrlParams include ImportUrlParams
# Authorize # Authorize
before_action :authorize_admin_project! before_action :authorize_admin_project!, only: [:new, :create]
before_action :require_namespace_project_creation_permission, only: :show
before_action :require_no_repo, only: [:new, :create] before_action :require_no_repo, only: [:new, :create]
before_action :redirect_if_progress, only: [:new, :create] before_action :redirect_if_progress, only: [:new, :create]
before_action :redirect_if_no_import, only: :show before_action :redirect_if_no_import, only: :show
...@@ -51,6 +52,10 @@ class Projects::ImportsController < Projects::ApplicationController ...@@ -51,6 +52,10 @@ class Projects::ImportsController < Projects::ApplicationController
end end
end end
def require_namespace_project_creation_permission
render_404 unless current_user.can?(:admin_project, @project) || current_user.can?(:create_projects, @project.namespace)
end
def redirect_if_progress def redirect_if_progress
if @project.import_in_progress? if @project.import_in_progress?
redirect_to project_import_path(@project) redirect_to project_import_path(@project)
......
---
title: Fix 404 when importing project with developer permission
merge_request: 35667
author:
type: fixed
...@@ -8,10 +8,14 @@ RSpec.describe Projects::ImportsController do ...@@ -8,10 +8,14 @@ RSpec.describe Projects::ImportsController do
before do before do
sign_in(user) sign_in(user)
project.add_maintainer(user)
end end
describe 'GET #show' do describe 'GET #show' do
context 'when the user has maintainer rights' do
before do
project.add_maintainer(user)
end
context 'when repository does not exists' do context 'when repository does not exists' do
it 'renders template' do it 'renders template' do
get :show, params: { namespace_id: project.namespace.to_param, project_id: project } get :show, params: { namespace_id: project.namespace.to_param, project_id: project }
...@@ -123,11 +127,46 @@ RSpec.describe Projects::ImportsController do ...@@ -123,11 +127,46 @@ RSpec.describe Projects::ImportsController do
end end
end end
context 'when project is in group' do
let(:project) { create(:project_empty_repo, import_url: 'https://github.com/vim/vim.git', namespace: group) }
context 'when user has developer access to group and import is in progress' do
let(:import_state) { project.import_state }
before do
group.add_developer(user)
import_state.update!(status: :started)
end
context 'when group allows developers to create projects' do
let(:group) { create(:group, project_creation_level: Gitlab::Access::DEVELOPER_MAINTAINER_PROJECT_ACCESS) }
it 'renders template' do
get :show, params: { namespace_id: project.namespace.to_param, project_id: project }
expect(response).to render_template :show
end
end
context 'when group prohibits developers to create projects' do
let(:group) { create(:group, project_creation_level: Gitlab::Access::MAINTAINER_PROJECT_ACCESS) }
it 'returns 404 response' do
get :show, params: { namespace_id: project.namespace.to_param, project_id: project }
expect(response).to have_gitlab_http_status(:not_found)
end
end
end
end
end
describe 'POST #create' do describe 'POST #create' do
let(:params) { { import_url: 'https://github.com/vim/vim.git', import_url_user: 'user', import_url_password: 'password' } } let(:params) { { import_url: 'https://github.com/vim/vim.git', import_url_user: 'user', import_url_password: 'password' } }
let(:project) { create(:project) } let(:project) { create(:project) }
before do before do
project.add_maintainer(user)
allow(RepositoryImportWorker).to receive(:perform_async) allow(RepositoryImportWorker).to receive(:perform_async)
post :create, params: { project: params, namespace_id: project.namespace.to_param, project_id: project } post :create, params: { project: params, namespace_id: project.namespace.to_param, project_id: project }
......
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