Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'spec/lib/gitlab/database/rename_reserved_paths_migration/v1/rename_projects_spec.rb')
-rw-r--r--spec/lib/gitlab/database/rename_reserved_paths_migration/v1/rename_projects_spec.rb190
1 files changed, 0 insertions, 190 deletions
diff --git a/spec/lib/gitlab/database/rename_reserved_paths_migration/v1/rename_projects_spec.rb b/spec/lib/gitlab/database/rename_reserved_paths_migration/v1/rename_projects_spec.rb
deleted file mode 100644
index d2665664fb0..00000000000
--- a/spec/lib/gitlab/database/rename_reserved_paths_migration/v1/rename_projects_spec.rb
+++ /dev/null
@@ -1,190 +0,0 @@
-# frozen_string_literal: true
-
-require 'spec_helper'
-
-RSpec.describe Gitlab::Database::RenameReservedPathsMigration::V1::RenameProjects, :delete,
-feature_category: :groups_and_projects do
- let(:migration) { FakeRenameReservedPathMigrationV1.new }
- let(:subject) { described_class.new(['the-path'], migration) }
- let(:project) do
- create(:project,
- :legacy_storage,
- path: 'the-path',
- namespace: create(:namespace, path: 'known-parent' ))
- end
-
- before do
- allow(migration).to receive(:say)
- TestEnv.clean_test_path
- end
-
- describe '#projects_for_paths' do
- it 'searches using nested paths' do
- namespace = create(:namespace, path: 'hello')
- project = create(:project, :legacy_storage, path: 'THE-path', namespace: namespace)
-
- result_ids = described_class.new(['Hello/the-path'], migration)
- .projects_for_paths.map(&:id)
-
- expect(result_ids).to contain_exactly(project.id)
- end
-
- it 'includes the correct projects' do
- project = create(:project, :legacy_storage, path: 'THE-path')
- _other_project = create(:project, :legacy_storage)
-
- result_ids = subject.projects_for_paths.map(&:id)
-
- expect(result_ids).to contain_exactly(project.id)
- end
- end
-
- describe '#rename_projects' do
- let!(:projects) { create_list(:project, 2, :legacy_storage, path: 'the-path') }
-
- it 'renames each project' do
- expect(subject).to receive(:rename_project).twice
-
- subject.rename_projects
- end
-
- it 'invalidates the markdown cache of related projects' do
- expect(subject).to receive(:remove_cached_html_for_projects)
- .with(a_collection_containing_exactly(*projects.map(&:id)))
-
- subject.rename_projects
- end
- end
-
- describe '#rename_project' do
- it 'renames path & route for the project' do
- expect(subject).to receive(:rename_path_for_routable)
- .with(project)
- .and_call_original
-
- subject.rename_project(project)
-
- expect(project.reload.path).to eq('the-path0')
- end
-
- it 'tracks the rename' do
- expect(subject).to receive(:track_rename)
- .with('project', 'known-parent/the-path', 'known-parent/the-path0')
-
- subject.rename_project(project)
- end
-
- it 'renames the folders for the project' do
- expect(subject).to receive(:move_project_folders).with(project, 'known-parent/the-path', 'known-parent/the-path0')
-
- subject.rename_project(project)
- end
- end
-
- describe '#move_project_folders' do
- it 'moves the wiki & the repo' do
- expect(subject).to receive(:move_repository)
- .with(project, 'known-parent/the-path.wiki', 'known-parent/the-path0.wiki')
- expect(subject).to receive(:move_repository)
- .with(project, 'known-parent/the-path', 'known-parent/the-path0')
-
- subject.move_project_folders(project, 'known-parent/the-path', 'known-parent/the-path0')
- end
-
- it 'does not move the repositories when hashed storage is enabled' do
- project.update!(storage_version: Project::HASHED_STORAGE_FEATURES[:repository])
-
- expect(subject).not_to receive(:move_repository)
-
- subject.move_project_folders(project, 'known-parent/the-path', 'known-parent/the-path0')
- end
-
- it 'moves uploads' do
- expect(subject).to receive(:move_uploads)
- .with('known-parent/the-path', 'known-parent/the-path0')
-
- subject.move_project_folders(project, 'known-parent/the-path', 'known-parent/the-path0')
- end
-
- it 'does not move uploads when hashed storage is enabled for attachments' do
- project.update!(storage_version: Project::HASHED_STORAGE_FEATURES[:attachments])
-
- expect(subject).not_to receive(:move_uploads)
-
- subject.move_project_folders(project, 'known-parent/the-path', 'known-parent/the-path0')
- end
-
- it 'moves pages' do
- expect(subject).to receive(:move_pages)
- .with('known-parent/the-path', 'known-parent/the-path0')
-
- subject.move_project_folders(project, 'known-parent/the-path', 'known-parent/the-path0')
- end
- end
-
- describe '#move_repository' do
- let(:known_parent) { create(:namespace, path: 'known-parent') }
- let(:project) { create(:project, :repository, :legacy_storage, path: 'the-path', namespace: known_parent) }
-
- it 'moves the repository for a project' do
- expected_repository = Gitlab::Git::Repository.new(
- project.repository_storage,
- 'known-parent/new-repo.git',
- nil,
- nil
- )
-
- subject.move_repository(project, 'known-parent/the-path', 'known-parent/new-repo')
-
- expect(expected_repository).to exist
- end
- end
-
- describe '#revert_renames', :redis do
- it 'renames the routes back to the previous values' do
- subject.rename_project(project)
-
- expect(subject).to receive(:perform_rename)
- .with(
- kind_of(Gitlab::Database::RenameReservedPathsMigration::V1::MigrationClasses::Project),
- 'known-parent/the-path0',
- 'known-parent/the-path'
- ).and_call_original
-
- subject.revert_renames
-
- expect(project.reload.path).to eq('the-path')
- expect(project.route.path).to eq('known-parent/the-path')
- end
-
- it 'moves the repositories back to their original place' do
- project.create_repository
- subject.rename_project(project)
-
- expected_repository = Gitlab::Git::Repository.new(
- project.repository_storage,
- 'known-parent/the-path.git',
- nil,
- nil
- )
-
- expect(subject).to receive(:move_project_folders)
- .with(
- kind_of(Gitlab::Database::RenameReservedPathsMigration::V1::MigrationClasses::Project),
- 'known-parent/the-path0',
- 'known-parent/the-path'
- ).and_call_original
-
- subject.revert_renames
-
- expect(expected_repository).to exist
- end
-
- it "doesn't break when the project was renamed" do
- subject.rename_project(project)
- project.update!(path: 'renamed-afterwards')
-
- expect { subject.revert_renames }.not_to raise_error
- end
- end
-end