2016-04-02 18:10:28 +05:30
|
|
|
require 'spec_helper'
|
|
|
|
|
2017-09-10 17:25:29 +05:30
|
|
|
describe Projects::ImportService do
|
|
|
|
let!(:project) { create(:project) }
|
2016-04-02 18:10:28 +05:30
|
|
|
let(:user) { project.creator }
|
|
|
|
|
|
|
|
subject { described_class.new(project, user) }
|
|
|
|
|
2018-03-17 18:26:18 +05:30
|
|
|
describe '#async?' do
|
|
|
|
it 'returns true for an asynchronous importer' do
|
|
|
|
importer_class = double(:importer, async?: true)
|
|
|
|
|
|
|
|
allow(subject).to receive(:has_importer?).and_return(true)
|
|
|
|
allow(subject).to receive(:importer_class).and_return(importer_class)
|
|
|
|
|
|
|
|
expect(subject).to be_async
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns false for a regular importer' do
|
|
|
|
importer_class = double(:importer, async?: false)
|
|
|
|
|
|
|
|
allow(subject).to receive(:has_importer?).and_return(true)
|
|
|
|
allow(subject).to receive(:importer_class).and_return(importer_class)
|
|
|
|
|
|
|
|
expect(subject).not_to be_async
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns false when the importer does not define #async?' do
|
|
|
|
importer_class = double(:importer)
|
|
|
|
|
|
|
|
allow(subject).to receive(:has_importer?).and_return(true)
|
|
|
|
allow(subject).to receive(:importer_class).and_return(importer_class)
|
|
|
|
|
|
|
|
expect(subject).not_to be_async
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns false when the importer does not exist' do
|
|
|
|
allow(subject).to receive(:has_importer?).and_return(false)
|
|
|
|
|
|
|
|
expect(subject).not_to be_async
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2016-04-02 18:10:28 +05:30
|
|
|
describe '#execute' do
|
|
|
|
context 'with unknown url' do
|
|
|
|
before do
|
|
|
|
project.import_url = Project::UNKNOWN_IMPORT_URL
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'succeeds if repository is created successfully' do
|
|
|
|
expect(project).to receive(:create_repository).and_return(true)
|
|
|
|
|
|
|
|
result = subject.execute
|
|
|
|
|
|
|
|
expect(result[:status]).to eq :success
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'fails if repository creation fails' do
|
|
|
|
expect(project).to receive(:create_repository).and_return(false)
|
|
|
|
|
|
|
|
result = subject.execute
|
|
|
|
|
|
|
|
expect(result[:status]).to eq :error
|
2017-09-10 17:25:29 +05:30
|
|
|
expect(result[:message]).to eq "Error importing repository #{project.import_url} into #{project.full_path} - The repository could not be created."
|
2016-04-02 18:10:28 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with known url' do
|
|
|
|
before do
|
|
|
|
project.import_url = 'https://github.com/vim/vim.git'
|
2017-08-17 22:00:37 +05:30
|
|
|
project.import_type = 'github'
|
2016-04-02 18:10:28 +05:30
|
|
|
end
|
|
|
|
|
2017-08-17 22:00:37 +05:30
|
|
|
context 'with a Github repository' do
|
2018-03-17 18:26:18 +05:30
|
|
|
it 'succeeds if repository import was scheduled' do
|
|
|
|
expect_any_instance_of(Gitlab::GithubImport::ParallelImporter)
|
|
|
|
.to receive(:execute)
|
|
|
|
.and_return(true)
|
2016-04-02 18:10:28 +05:30
|
|
|
|
2017-08-17 22:00:37 +05:30
|
|
|
result = subject.execute
|
2016-04-02 18:10:28 +05:30
|
|
|
|
2017-08-17 22:00:37 +05:30
|
|
|
expect(result[:status]).to eq :success
|
|
|
|
end
|
|
|
|
|
2018-03-17 18:26:18 +05:30
|
|
|
it 'fails if repository import was not scheduled' do
|
|
|
|
expect_any_instance_of(Gitlab::GithubImport::ParallelImporter)
|
|
|
|
.to receive(:execute)
|
|
|
|
.and_return(false)
|
2017-08-17 22:00:37 +05:30
|
|
|
|
|
|
|
result = subject.execute
|
|
|
|
|
|
|
|
expect(result[:status]).to eq :error
|
|
|
|
end
|
2016-04-02 18:10:28 +05:30
|
|
|
end
|
|
|
|
|
2017-08-17 22:00:37 +05:30
|
|
|
context 'with a non Github repository' do
|
|
|
|
before do
|
|
|
|
project.import_url = 'https://bitbucket.org/vim/vim.git'
|
|
|
|
project.import_type = 'bitbucket'
|
|
|
|
end
|
2016-04-02 18:10:28 +05:30
|
|
|
|
2017-08-17 22:00:37 +05:30
|
|
|
it 'succeeds if repository import is successfully' do
|
|
|
|
expect_any_instance_of(Gitlab::Shell).to receive(:import_repository).and_return(true)
|
|
|
|
expect_any_instance_of(Gitlab::BitbucketImport::Importer).to receive(:execute).and_return(true)
|
2016-04-02 18:10:28 +05:30
|
|
|
|
2017-08-17 22:00:37 +05:30
|
|
|
result = subject.execute
|
|
|
|
|
|
|
|
expect(result[:status]).to eq :success
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'fails if repository import fails' do
|
|
|
|
expect_any_instance_of(Gitlab::Shell).to receive(:import_repository).and_raise(Gitlab::Shell::Error.new('Failed to import the repository'))
|
|
|
|
|
|
|
|
result = subject.execute
|
|
|
|
|
|
|
|
expect(result[:status]).to eq :error
|
2017-09-10 17:25:29 +05:30
|
|
|
expect(result[:message]).to eq "Error importing repository #{project.import_url} into #{project.full_path} - Failed to import the repository"
|
2017-08-17 22:00:37 +05:30
|
|
|
end
|
2016-04-02 18:10:28 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with valid importer' do
|
|
|
|
before do
|
|
|
|
stub_github_omniauth_provider
|
|
|
|
|
|
|
|
project.import_url = 'https://github.com/vim/vim.git'
|
|
|
|
project.import_type = 'github'
|
|
|
|
|
|
|
|
allow(project).to receive(:import_data).and_return(double.as_null_object)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'succeeds if importer succeeds' do
|
2018-03-17 18:26:18 +05:30
|
|
|
allow_any_instance_of(Gitlab::GithubImport::ParallelImporter)
|
|
|
|
.to receive(:execute).and_return(true)
|
2016-04-02 18:10:28 +05:30
|
|
|
|
|
|
|
result = subject.execute
|
|
|
|
|
|
|
|
expect(result[:status]).to eq :success
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'fails if importer fails' do
|
2018-03-17 18:26:18 +05:30
|
|
|
allow_any_instance_of(Gitlab::GithubImport::ParallelImporter)
|
|
|
|
.to receive(:execute)
|
|
|
|
.and_return(false)
|
2016-04-02 18:10:28 +05:30
|
|
|
|
|
|
|
result = subject.execute
|
|
|
|
|
|
|
|
expect(result[:status]).to eq :error
|
2016-11-03 12:29:30 +05:30
|
|
|
end
|
2016-04-02 18:10:28 +05:30
|
|
|
end
|
|
|
|
|
2017-08-17 22:00:37 +05:30
|
|
|
context 'with blocked import_URL' do
|
|
|
|
it 'fails with localhost' do
|
|
|
|
project.import_url = 'https://localhost:9000/vim/vim.git'
|
|
|
|
|
|
|
|
result = described_class.new(project, user).execute
|
|
|
|
|
|
|
|
expect(result[:status]).to eq :error
|
2018-05-09 12:01:36 +05:30
|
|
|
expect(result[:message]).to include('Requests to localhost are not allowed')
|
2017-08-17 22:00:37 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
it 'fails with port 25' do
|
|
|
|
project.import_url = "https://github.com:25/vim/vim.git"
|
|
|
|
|
|
|
|
result = described_class.new(project, user).execute
|
|
|
|
|
|
|
|
expect(result[:status]).to eq :error
|
2018-05-09 12:01:36 +05:30
|
|
|
expect(result[:message]).to include('Only allowed ports are 22, 80, 443')
|
2017-08-17 22:00:37 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2016-04-02 18:10:28 +05:30
|
|
|
def stub_github_omniauth_provider
|
|
|
|
provider = OpenStruct.new(
|
2016-06-02 11:05:42 +05:30
|
|
|
'name' => 'github',
|
|
|
|
'app_id' => 'asd123',
|
|
|
|
'app_secret' => 'asd123',
|
|
|
|
'args' => {
|
|
|
|
'client_options' => {
|
|
|
|
'site' => 'https://github.com/api/v3',
|
|
|
|
'authorize_url' => 'https://github.com/login/oauth/authorize',
|
|
|
|
'token_url' => 'https://github.com/login/oauth/access_token'
|
|
|
|
}
|
|
|
|
}
|
2016-04-02 18:10:28 +05:30
|
|
|
)
|
|
|
|
|
2017-09-10 17:25:29 +05:30
|
|
|
stub_omniauth_setting(providers: [provider])
|
2016-04-02 18:10:28 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|