Commit fcf8f95e authored by Stan Hu's avatar Stan Hu

Merge branch '1363-fetch-remote-default-branch-doesn-t-work-with-ssh-mirrors' into 'master'

Don't synchronize default branch when updating a SSH mirror

See merge request gitlab-org/gitlab-ee!7891
parents 6d06f079 42ae81af
...@@ -63,9 +63,20 @@ module Projects ...@@ -63,9 +63,20 @@ module Projects
# Update the default branch querying the remote to determine its HEAD # Update the default branch querying the remote to determine its HEAD
def update_root_ref def update_root_ref
# Fetch remote default branch doesn't work with SSH mirrors:
# https://gitlab.com/gitlab-org/gitaly/issues/1363
return if ssh_mirror?
project.update_root_ref(::Repository::MIRROR_REMOTE) project.update_root_ref(::Repository::MIRROR_REMOTE)
end end
def ssh_mirror?
uri = Addressable::URI.parse(project.import_url)
uri.scheme.present? && uri.scheme == 'ssh'
rescue Addressable::URI::InvalidURIError
false
end
def update_tags(&block) def update_tags(&block)
old_tags = repository_tags_with_target.each_with_object({}) { |tag, tags| tags[tag.name] = tag } old_tags = repository_tags_with_target.each_with_object({}) { |tag, tags| tags[tag.name] = tag }
......
---
title: Don't synchronize default branch when updating a SSH mirror
merge_request: 7891
author:
type: fixed
...@@ -209,18 +209,30 @@ describe Projects::UpdateMirrorService do ...@@ -209,18 +209,30 @@ describe Projects::UpdateMirrorService do
end end
end end
it 'updates the default branch when HEAD has changed' do context 'synchronize the default branch' do
stub_fetch_mirror(project) it 'updates the default branch when HEAD has changed' do
stub_find_remote_root_ref(project, ref: 'new-branch') stub_fetch_mirror(project)
stub_find_remote_root_ref(project, ref: 'new-branch')
expect { service.execute }.to change { project.default_branch }.from('master').to('new-branch') expect { service.execute }.to change { project.default_branch }.from('master').to('new-branch')
end end
it 'does not update the default branch when HEAD does not change' do it 'does not update the default branch when HEAD does not change' do
stub_fetch_mirror(project) stub_fetch_mirror(project)
stub_find_remote_root_ref(project, ref: 'master') stub_find_remote_root_ref(project, ref: 'master')
expect { service.execute }.not_to change { project.default_branch } expect { service.execute }.not_to change { project.default_branch }
end
it 'does not update the default branch with SSH mirrors' do
project.update(import_url: 'ssh://git@example.com/foo/bar.git')
expect(project.repository)
.not_to receive(:find_remote_root_ref)
.with('upstream')
service.execute
end
end end
it "fails when the mirror user doesn't have access" do it "fails when the mirror user doesn't have access" do
......
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