2019-11-14 07:06:30 -05:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require 'spec_helper'
|
|
|
|
|
|
|
|
describe API::GroupExport do
|
|
|
|
let_it_be(:group) { create(:group) }
|
|
|
|
let_it_be(:user) { create(:user) }
|
|
|
|
|
|
|
|
let(:path) { "/groups/#{group.id}/export" }
|
|
|
|
let(:download_path) { "/groups/#{group.id}/export/download" }
|
|
|
|
|
|
|
|
let(:export_path) { "#{Dir.tmpdir}/group_export_spec" }
|
|
|
|
|
|
|
|
before do
|
|
|
|
allow_next_instance_of(Gitlab::ImportExport) do |import_export|
|
|
|
|
expect(import_export).to receive(:storage_path).and_return(export_path)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
after do
|
|
|
|
FileUtils.rm_rf(export_path, secure: true)
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'GET /groups/:group_id/export/download' do
|
|
|
|
let(:upload) { ImportExportUpload.new(group: group) }
|
|
|
|
|
|
|
|
before do
|
|
|
|
stub_uploads_object_storage(ImportExportUploader)
|
|
|
|
|
|
|
|
group.add_owner(user)
|
|
|
|
end
|
|
|
|
|
2020-01-28 07:08:44 -05:00
|
|
|
context 'group_import_export feature flag enabled' do
|
2019-11-14 07:06:30 -05:00
|
|
|
before do
|
2020-01-28 07:08:44 -05:00
|
|
|
stub_feature_flags(group_import_export: true)
|
2019-11-14 07:06:30 -05:00
|
|
|
end
|
|
|
|
|
2020-01-28 07:08:44 -05:00
|
|
|
context 'when export file exists' do
|
|
|
|
before do
|
|
|
|
upload.export_file = fixture_file_upload('spec/fixtures/group_export.tar.gz', "`/tar.gz")
|
|
|
|
upload.save!
|
|
|
|
end
|
2019-11-14 07:06:30 -05:00
|
|
|
|
2020-01-28 07:08:44 -05:00
|
|
|
it 'downloads exported group archive' do
|
|
|
|
get api(download_path, user)
|
2019-11-14 07:06:30 -05:00
|
|
|
|
2020-02-25 07:08:48 -05:00
|
|
|
expect(response).to have_gitlab_http_status(:ok)
|
2020-01-28 07:08:44 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
context 'when export_file.file does not exist' do
|
|
|
|
before do
|
|
|
|
expect_next_instance_of(ImportExportUploader) do |uploader|
|
|
|
|
expect(uploader).to receive(:file).and_return(nil)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns 404' do
|
|
|
|
get api(download_path, user)
|
|
|
|
|
2020-02-25 07:08:48 -05:00
|
|
|
expect(response).to have_gitlab_http_status(:not_found)
|
2019-11-14 07:06:30 -05:00
|
|
|
end
|
|
|
|
end
|
2020-01-28 07:08:44 -05:00
|
|
|
end
|
2019-11-14 07:06:30 -05:00
|
|
|
|
2020-01-28 07:08:44 -05:00
|
|
|
context 'when export file does not exist' do
|
2019-11-14 07:06:30 -05:00
|
|
|
it 'returns 404' do
|
|
|
|
get api(download_path, user)
|
|
|
|
|
2020-02-25 07:08:48 -05:00
|
|
|
expect(response).to have_gitlab_http_status(:not_found)
|
2019-11-14 07:06:30 -05:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2020-01-28 07:08:44 -05:00
|
|
|
context 'group_import_export feature flag disabled' do
|
|
|
|
before do
|
|
|
|
stub_feature_flags(group_import_export: false)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'responds with 404 Not Found' do
|
2019-11-14 07:06:30 -05:00
|
|
|
get api(download_path, user)
|
|
|
|
|
2020-02-25 07:08:48 -05:00
|
|
|
expect(response).to have_gitlab_http_status(:not_found)
|
2019-11-14 07:06:30 -05:00
|
|
|
end
|
|
|
|
end
|
2020-06-03 08:08:21 -04:00
|
|
|
|
|
|
|
context 'when the requests have exceeded the rate limit' do
|
|
|
|
before do
|
|
|
|
allow(Gitlab::ApplicationRateLimiter)
|
|
|
|
.to receive(:increment)
|
|
|
|
.and_return(Gitlab::ApplicationRateLimiter.rate_limits[:group_download_export][:threshold] + 1)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'throttles the endpoint' do
|
|
|
|
get api(download_path, user)
|
|
|
|
|
|
|
|
expect(json_response["message"])
|
|
|
|
.to include('error' => 'This endpoint has been requested too many times. Try again later.')
|
|
|
|
expect(response).to have_gitlab_http_status :too_many_requests
|
|
|
|
end
|
|
|
|
end
|
2019-11-14 07:06:30 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
describe 'POST /groups/:group_id/export' do
|
2020-01-28 07:08:44 -05:00
|
|
|
context 'group_import_export feature flag enabled' do
|
2019-11-14 07:06:30 -05:00
|
|
|
before do
|
2020-01-28 07:08:44 -05:00
|
|
|
stub_feature_flags(group_import_export: true)
|
2019-11-14 07:06:30 -05:00
|
|
|
end
|
|
|
|
|
2020-01-28 07:08:44 -05:00
|
|
|
context 'when user is a group owner' do
|
|
|
|
before do
|
|
|
|
group.add_owner(user)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'accepts download' do
|
|
|
|
post api(path, user)
|
|
|
|
|
2020-02-25 07:08:48 -05:00
|
|
|
expect(response).to have_gitlab_http_status(:accepted)
|
2020-01-28 07:08:44 -05:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2020-04-09 08:09:24 -04:00
|
|
|
context 'when the export cannot be started' do
|
|
|
|
before do
|
|
|
|
group.add_owner(user)
|
|
|
|
allow(GroupExportWorker).to receive(:perform_async).and_return(nil)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns an error' do
|
|
|
|
post api(path, user)
|
|
|
|
|
|
|
|
expect(response).to have_gitlab_http_status(:error)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2020-01-28 07:08:44 -05:00
|
|
|
context 'when user is not a group owner' do
|
|
|
|
before do
|
|
|
|
group.add_developer(user)
|
|
|
|
end
|
2019-11-14 07:06:30 -05:00
|
|
|
|
2020-01-28 07:08:44 -05:00
|
|
|
it 'forbids the request' do
|
|
|
|
post api(path, user)
|
|
|
|
|
2020-02-25 07:08:48 -05:00
|
|
|
expect(response).to have_gitlab_http_status(:forbidden)
|
2020-01-28 07:08:44 -05:00
|
|
|
end
|
2019-11-14 07:06:30 -05:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2020-01-28 07:08:44 -05:00
|
|
|
context 'group_import_export feature flag disabled' do
|
2019-11-14 07:06:30 -05:00
|
|
|
before do
|
2020-01-28 07:08:44 -05:00
|
|
|
stub_feature_flags(group_import_export: false)
|
2019-11-14 07:06:30 -05:00
|
|
|
end
|
|
|
|
|
2020-01-28 07:08:44 -05:00
|
|
|
it 'responds with 404 Not Found' do
|
2019-11-14 07:06:30 -05:00
|
|
|
post api(path, user)
|
|
|
|
|
2020-02-25 07:08:48 -05:00
|
|
|
expect(response).to have_gitlab_http_status(:not_found)
|
2019-11-14 07:06:30 -05:00
|
|
|
end
|
|
|
|
end
|
2020-06-03 08:08:21 -04:00
|
|
|
|
|
|
|
context 'when the requests have exceeded the rate limit' do
|
|
|
|
before do
|
|
|
|
group.add_owner(user)
|
|
|
|
|
|
|
|
allow(Gitlab::ApplicationRateLimiter)
|
|
|
|
.to receive(:increment)
|
|
|
|
.and_return(Gitlab::ApplicationRateLimiter.rate_limits[:group_export][:threshold] + 1)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'throttles the endpoint' do
|
|
|
|
post api(path, user)
|
|
|
|
|
|
|
|
expect(json_response["message"])
|
|
|
|
.to include('error' => 'This endpoint has been requested too many times. Try again later.')
|
|
|
|
expect(response).to have_gitlab_http_status :too_many_requests
|
|
|
|
end
|
|
|
|
end
|
2019-11-14 07:06:30 -05:00
|
|
|
end
|
|
|
|
end
|