Commit c7c9b420 authored by Stan Hu's avatar Stan Hu

Merge branch 'mk/geo/fix-renaming-namespace-with-subgroup' into 'master'

Geo: Fix repo, wiki, and upload replication when renaming a namespace that has subgroups, without hashed storage enabled

Closes #6012

See merge request gitlab-org/gitlab-ee!5704
parents 08b25f6f e91b1a1d
...@@ -51,12 +51,10 @@ module EE ...@@ -51,12 +51,10 @@ module EE
if succeeded if succeeded
all_projects.each do |project| all_projects.each do |project|
old_path_with_namespace = File.join(full_path_was, project.path)
::Geo::RepositoryRenamedEventStore.new( ::Geo::RepositoryRenamedEventStore.new(
project, project,
old_path: project.path, old_path: project.path,
old_path_with_namespace: old_path_with_namespace old_path_with_namespace: old_path_with_namespace_for(project)
).create ).create
end end
end end
...@@ -64,6 +62,10 @@ module EE ...@@ -64,6 +62,10 @@ module EE
succeeded succeeded
end end
def old_path_with_namespace_for(project)
project.full_path.sub(/\A#{Regexp.escape(full_path)}/, full_path_was)
end
# Checks features (i.e. https://about.gitlab.com/products/) availabily # Checks features (i.e. https://about.gitlab.com/products/) availabily
# for a given Namespace plan. This method should consider ancestor groups # for a given Namespace plan. This method should consider ancestor groups
# being licensed. # being licensed.
......
---
title: 'Geo: Fix repo, wiki, and upload replication when renaming a namespace that has subgroups'
merge_request: 5704
author:
type: fixed
...@@ -98,26 +98,41 @@ describe Namespace do ...@@ -98,26 +98,41 @@ describe Namespace do
set(:primary) { create(:geo_node, :primary) } set(:primary) { create(:geo_node, :primary) }
set(:secondary) { create(:geo_node) } set(:secondary) { create(:geo_node) }
let(:gitlab_shell) { Gitlab::Shell.new } let(:gitlab_shell) { Gitlab::Shell.new }
let(:parent_group) { create(:group) }
let(:child_group) { create(:group, name: 'child', path: 'child', parent: parent_group) }
let!(:project_legacy) { create(:project_empty_repo, :legacy_storage, namespace: parent_group) }
let!(:project_child_hashed) { create(:project, namespace: child_group) }
let!(:project_child_legacy) { create(:project_empty_repo, :legacy_storage, namespace: child_group) }
let!(:full_path_was) { "#{parent_group.full_path}_old" }
it 'logs the Geo::RepositoryRenamedEvent for each project inside namespace' do before do
parent = create(:namespace) new_path = parent_group.full_path
child = create(:group, name: 'child', path: 'child', parent: parent)
project_legacy_storage = create(:project_empty_repo, :legacy_storage, namespace: parent) allow(parent_group).to receive(:gitlab_shell).and_return(gitlab_shell)
create(:project, namespace: child) allow(parent_group).to receive(:path_changed?).and_return(true)
create(:project_empty_repo, :legacy_storage, namespace: child) allow(parent_group).to receive(:full_path_was).and_return(full_path_was)
full_path_was = "#{parent.full_path}_old" allow(parent_group).to receive(:full_path).and_return(new_path)
new_path = parent.full_path
allow(parent).to receive(:gitlab_shell).and_return(gitlab_shell)
allow(parent).to receive(:path_changed?).and_return(true)
allow(parent).to receive(:full_path_was).and_return(full_path_was)
allow(parent).to receive(:full_path).and_return(new_path)
allow(gitlab_shell).to receive(:mv_namespace) allow(gitlab_shell).to receive(:mv_namespace)
.with(project_legacy_storage.repository_storage, full_path_was, new_path) .with(project_legacy.repository_storage, full_path_was, new_path)
.and_return(true) .and_return(true)
end
it 'logs the Geo::RepositoryRenamedEvent for each project inside namespace' do
expect { parent_group.move_dir }.to change(Geo::RepositoryRenamedEvent, :count).by(3)
end
it 'properly builds old_path_with_namespace' do
parent_group.move_dir
actual = Geo::RepositoryRenamedEvent.last(3).map(&:old_path_with_namespace)
expected = %W[
#{full_path_was}/#{project_legacy.path}
#{full_path_was}/child/#{project_child_hashed.path}
#{full_path_was}/child/#{project_child_legacy.path}
]
expect { parent.move_dir }.to change(Geo::RepositoryRenamedEvent, :count).by(3) expect(actual).to match_array(expected)
end end
end end
end end
......
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