diff options
author | Robert Speicher <robert@gitlab.com> | 2017-04-18 00:22:34 +0000 |
---|---|---|
committer | Robert Speicher <robert@gitlab.com> | 2017-04-18 00:22:34 +0000 |
commit | 40ab0e9168382ea446be721aac22c901fa983e3e (patch) | |
tree | b5175c2cdbd730b13c182905eb8074f0552edfd4 | |
parent | dbcfbd68b6b2b4c62ba5381317296b23002e3067 (diff) | |
parent | bf0717802f9bea5222f0149ebc7a843664a27ef7 (diff) | |
download | gitlab-ce-40ab0e9168382ea446be721aac22c901fa983e3e.tar.gz |
Merge branch 'fix/30961' into 'master'
Does not remove the GitHub remote when importing from GitHub
Closes #30961
See merge request !10750
-rw-r--r-- | app/services/projects/import_service.rb | 1 | ||||
-rw-r--r-- | lib/tasks/import.rake | 1 | ||||
-rw-r--r-- | spec/services/projects/import_service_spec.rb | 9 |
3 files changed, 9 insertions, 2 deletions
diff --git a/app/services/projects/import_service.rb b/app/services/projects/import_service.rb index 4c72d5e117d..eea17e24903 100644 --- a/app/services/projects/import_service.rb +++ b/app/services/projects/import_service.rb @@ -59,7 +59,6 @@ module Projects project.repository.add_remote(project.import_type, project.import_url) project.repository.set_remote_as_mirror(project.import_type) project.repository.fetch_remote(project.import_type, forced: true) - project.repository.remove_remote(project.import_type) end def import_data diff --git a/lib/tasks/import.rake b/lib/tasks/import.rake index 15131fbf755..a9dad6a1bf0 100644 --- a/lib/tasks/import.rake +++ b/lib/tasks/import.rake @@ -52,7 +52,6 @@ class NewImporter < ::Gitlab::GithubImport::Importer project.repository.add_remote(project.import_type, project.import_url) project.repository.set_remote_as_mirror(project.import_type) project.repository.fetch_remote(project.import_type, forced: true) - project.repository.remove_remote(project.import_type) rescue => e # Expire cache to prevent scenarios such as: # 1. First import failed, but the repo was imported successfully, so +exists?+ returns true diff --git a/spec/services/projects/import_service_spec.rb b/spec/services/projects/import_service_spec.rb index 09cfa36b3b9..852a4ac852f 100644 --- a/spec/services/projects/import_service_spec.rb +++ b/spec/services/projects/import_service_spec.rb @@ -54,6 +54,15 @@ describe Projects::ImportService, services: true do expect(result[:status]).to eq :error expect(result[:message]).to eq "Error importing repository #{project.import_url} into #{project.path_with_namespace} - Failed to import the repository" end + + it 'does not remove the GitHub remote' do + expect_any_instance_of(Repository).to receive(:fetch_remote).and_return(true) + expect_any_instance_of(Gitlab::GithubImport::Importer).to receive(:execute).and_return(true) + + subject.execute + + expect(project.repository.raw_repository.remote_names).to include('github') + end end context 'with a non Github repository' do |