2018-02-09 09:58:28 -05:00
|
|
|
require 'spec_helper'
|
|
|
|
|
|
|
|
describe API::ProjectImport do
|
|
|
|
let(:export_path) { "#{Dir.tmpdir}/project_export_spec" }
|
|
|
|
let(:user) { create(:user) }
|
2018-06-06 17:26:00 -04:00
|
|
|
let(:file) { File.join('spec', 'features', 'projects', 'import_export', 'test_project_export.tar.gz') }
|
2018-02-12 04:13:08 -05:00
|
|
|
let(:namespace) { create(:group) }
|
2018-02-09 09:58:28 -05:00
|
|
|
before do
|
|
|
|
allow_any_instance_of(Gitlab::ImportExport).to receive(:storage_path).and_return(export_path)
|
2018-07-26 06:55:21 -04:00
|
|
|
stub_uploads_object_storage(FileUploader)
|
2018-02-09 09:58:28 -05:00
|
|
|
|
2018-02-12 09:26:59 -05:00
|
|
|
namespace.add_owner(user)
|
2018-02-09 09:58:28 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
after do
|
|
|
|
FileUtils.rm_rf(export_path, secure: true)
|
|
|
|
end
|
|
|
|
|
2018-02-12 04:13:08 -05:00
|
|
|
describe 'POST /projects/import' do
|
2018-02-13 04:54:04 -05:00
|
|
|
it 'schedules an import using a namespace' do
|
2018-02-14 08:55:11 -05:00
|
|
|
stub_import(namespace)
|
2018-02-09 09:58:28 -05:00
|
|
|
|
2018-12-17 17:52:17 -05:00
|
|
|
post api('/projects/import', user), params: { path: 'test-import', file: fixture_file_upload(file), namespace: namespace.id }
|
2018-02-13 05:24:14 -05:00
|
|
|
|
|
|
|
expect(response).to have_gitlab_http_status(201)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'schedules an import using the namespace path' do
|
2018-02-14 08:55:11 -05:00
|
|
|
stub_import(namespace)
|
2018-02-13 05:24:14 -05:00
|
|
|
|
2018-12-17 17:52:17 -05:00
|
|
|
post api('/projects/import', user), params: { path: 'test-import', file: fixture_file_upload(file), namespace: namespace.full_path }
|
2018-02-12 04:13:08 -05:00
|
|
|
|
2018-02-12 10:02:15 -05:00
|
|
|
expect(response).to have_gitlab_http_status(201)
|
2018-02-12 04:13:08 -05:00
|
|
|
end
|
2018-02-13 04:54:04 -05:00
|
|
|
|
|
|
|
it 'schedules an import at the user namespace level' do
|
2018-02-14 08:46:40 -05:00
|
|
|
stub_import(user.namespace)
|
2018-02-13 04:54:04 -05:00
|
|
|
|
2018-12-17 17:52:17 -05:00
|
|
|
post api('/projects/import', user), params: { path: 'test-import2', file: fixture_file_upload(file) }
|
2018-02-13 04:54:04 -05:00
|
|
|
|
|
|
|
expect(response).to have_gitlab_http_status(201)
|
|
|
|
end
|
|
|
|
|
2018-08-16 07:40:03 -04:00
|
|
|
it 'does not schedule an import for a namespace that does not exist' do
|
2018-11-27 04:41:27 -05:00
|
|
|
expect_any_instance_of(ProjectImportState).not_to receive(:schedule)
|
2018-02-16 12:03:34 -05:00
|
|
|
expect(::Projects::CreateService).not_to receive(:new)
|
2018-02-14 08:46:40 -05:00
|
|
|
|
2018-12-17 17:52:17 -05:00
|
|
|
post api('/projects/import', user), params: { namespace: 'nonexistent', path: 'test-import2', file: fixture_file_upload(file) }
|
2018-02-14 08:46:40 -05:00
|
|
|
|
|
|
|
expect(response).to have_gitlab_http_status(404)
|
|
|
|
expect(json_response['message']).to eq('404 Namespace Not Found')
|
|
|
|
end
|
|
|
|
|
2018-02-13 04:54:04 -05:00
|
|
|
it 'does not schedule an import if the user has no permission to the namespace' do
|
2018-11-27 04:41:27 -05:00
|
|
|
expect_any_instance_of(ProjectImportState).not_to receive(:schedule)
|
2018-02-13 04:54:04 -05:00
|
|
|
|
|
|
|
post(api('/projects/import', create(:user)),
|
2018-12-17 17:52:17 -05:00
|
|
|
params: {
|
|
|
|
path: 'test-import3',
|
|
|
|
file: fixture_file_upload(file),
|
|
|
|
namespace: namespace.full_path
|
|
|
|
})
|
2018-02-13 04:54:04 -05:00
|
|
|
|
2018-02-14 08:46:40 -05:00
|
|
|
expect(response).to have_gitlab_http_status(404)
|
|
|
|
expect(json_response['message']).to eq('404 Namespace Not Found')
|
2018-02-13 04:54:04 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
it 'does not schedule an import if the user uploads no valid file' do
|
2018-11-27 04:41:27 -05:00
|
|
|
expect_any_instance_of(ProjectImportState).not_to receive(:schedule)
|
2018-02-13 04:54:04 -05:00
|
|
|
|
2018-12-17 17:52:17 -05:00
|
|
|
post api('/projects/import', user), params: { path: 'test-import3', file: './random/test' }
|
2018-02-13 04:54:04 -05:00
|
|
|
|
|
|
|
expect(response).to have_gitlab_http_status(400)
|
|
|
|
expect(json_response['error']).to eq('file is invalid')
|
|
|
|
end
|
2018-02-14 08:46:40 -05:00
|
|
|
|
2018-03-29 09:08:31 -04:00
|
|
|
it 'stores params that can be overridden' do
|
2018-03-29 07:57:21 -04:00
|
|
|
stub_import(namespace)
|
|
|
|
override_params = { 'description' => 'Hello world' }
|
|
|
|
|
|
|
|
post api('/projects/import', user),
|
2018-12-17 17:52:17 -05:00
|
|
|
params: {
|
|
|
|
path: 'test-import',
|
|
|
|
file: fixture_file_upload(file),
|
|
|
|
namespace: namespace.id,
|
|
|
|
override_params: override_params
|
|
|
|
}
|
2018-03-29 07:57:21 -04:00
|
|
|
import_project = Project.find(json_response['id'])
|
|
|
|
|
|
|
|
expect(import_project.import_data.data['override_params']).to eq(override_params)
|
|
|
|
end
|
|
|
|
|
2018-03-29 09:08:31 -04:00
|
|
|
it 'does not store params that are not allowed' do
|
2018-03-29 07:57:21 -04:00
|
|
|
stub_import(namespace)
|
|
|
|
override_params = { 'not_allowed' => 'Hello world' }
|
|
|
|
|
|
|
|
post api('/projects/import', user),
|
2018-12-17 17:52:17 -05:00
|
|
|
params: {
|
|
|
|
path: 'test-import',
|
|
|
|
file: fixture_file_upload(file),
|
|
|
|
namespace: namespace.id,
|
|
|
|
override_params: override_params
|
|
|
|
}
|
2018-03-29 07:57:21 -04:00
|
|
|
import_project = Project.find(json_response['id'])
|
|
|
|
|
|
|
|
expect(import_project.import_data.data['override_params']).to be_empty
|
|
|
|
end
|
|
|
|
|
2018-03-29 09:08:31 -04:00
|
|
|
it 'correctly overrides params during the import' do
|
|
|
|
override_params = { 'description' => 'Hello world' }
|
|
|
|
|
2018-07-23 00:34:54 -04:00
|
|
|
perform_enqueued_jobs do
|
2018-03-29 09:08:31 -04:00
|
|
|
post api('/projects/import', user),
|
2018-12-17 17:52:17 -05:00
|
|
|
params: {
|
|
|
|
path: 'test-import',
|
|
|
|
file: fixture_file_upload(file),
|
|
|
|
namespace: namespace.id,
|
|
|
|
override_params: override_params
|
|
|
|
}
|
2018-03-29 09:08:31 -04:00
|
|
|
end
|
|
|
|
import_project = Project.find(json_response['id'])
|
|
|
|
|
|
|
|
expect(import_project.description).to eq('Hello world')
|
|
|
|
end
|
|
|
|
|
2018-04-06 11:23:49 -04:00
|
|
|
context 'when target path already exists in namespace' do
|
|
|
|
let(:existing_project) { create(:project, namespace: user.namespace) }
|
|
|
|
|
|
|
|
it 'does not schedule an import' do
|
2018-11-27 04:41:27 -05:00
|
|
|
expect_any_instance_of(ProjectImportState).not_to receive(:schedule)
|
2018-04-06 11:23:49 -04:00
|
|
|
|
2018-12-17 17:52:17 -05:00
|
|
|
post api('/projects/import', user), params: { path: existing_project.path, file: fixture_file_upload(file) }
|
2018-04-06 11:23:49 -04:00
|
|
|
|
|
|
|
expect(response).to have_gitlab_http_status(400)
|
|
|
|
expect(json_response['message']).to eq('Name has already been taken')
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when param overwrite is true' do
|
|
|
|
it 'schedules an import' do
|
|
|
|
stub_import(user.namespace)
|
|
|
|
|
2018-12-17 17:52:17 -05:00
|
|
|
post api('/projects/import', user), params: { path: existing_project.path, file: fixture_file_upload(file), overwrite: true }
|
2018-04-06 11:23:49 -04:00
|
|
|
|
|
|
|
expect(response).to have_gitlab_http_status(201)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-02-14 08:46:40 -05:00
|
|
|
def stub_import(namespace)
|
2018-11-27 04:41:27 -05:00
|
|
|
expect_any_instance_of(ProjectImportState).to receive(:schedule)
|
2018-02-16 12:03:34 -05:00
|
|
|
expect(::Projects::CreateService).to receive(:new).with(user, hash_including(namespace_id: namespace.id)).and_call_original
|
2018-02-14 08:46:40 -05:00
|
|
|
end
|
2018-02-12 04:13:08 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
describe 'GET /projects/:id/import' do
|
|
|
|
it 'returns the import status' do
|
2018-05-02 09:35:04 -04:00
|
|
|
project = create(:project, :import_started)
|
2018-07-11 10:36:08 -04:00
|
|
|
project.add_maintainer(user)
|
2018-02-12 04:13:08 -05:00
|
|
|
|
|
|
|
get api("/projects/#{project.id}/import", user)
|
|
|
|
|
|
|
|
expect(response).to have_gitlab_http_status(200)
|
2018-02-12 06:40:55 -05:00
|
|
|
expect(json_response).to include('import_status' => 'started')
|
2018-02-12 04:13:08 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns the import status and the error if failed' do
|
2018-05-02 09:35:04 -04:00
|
|
|
project = create(:project, :import_failed)
|
2018-07-11 10:36:08 -04:00
|
|
|
project.add_maintainer(user)
|
2018-07-02 06:43:06 -04:00
|
|
|
project.import_state.update(last_error: 'error')
|
2018-02-12 04:13:08 -05:00
|
|
|
|
|
|
|
get api("/projects/#{project.id}/import", user)
|
|
|
|
|
|
|
|
expect(response).to have_gitlab_http_status(200)
|
2018-02-12 06:40:55 -05:00
|
|
|
expect(json_response).to include('import_status' => 'failed',
|
2018-02-12 08:46:47 -05:00
|
|
|
'import_error' => 'error')
|
2018-02-12 04:13:08 -05:00
|
|
|
end
|
2018-02-09 09:58:28 -05:00
|
|
|
end
|
|
|
|
end
|