debian-mirror-gitlab/spec/services/projects/hashed_storage/migrate_repository_service_spec.rb

117 lines
4 KiB
Ruby
Raw Normal View History

2019-07-31 22:56:46 +05:30
# frozen_string_literal: true
2018-03-17 18:26:18 +05:30
require 'spec_helper'
describe Projects::HashedStorage::MigrateRepositoryService do
2018-12-05 23:21:45 +05:30
include GitHelpers
2018-03-17 18:26:18 +05:30
let(:gitlab_shell) { Gitlab::Shell.new }
2018-03-27 19:54:05 +05:30
let(:project) { create(:project, :legacy_storage, :repository, :wiki_repo) }
2018-03-17 18:26:18 +05:30
let(:legacy_storage) { Storage::LegacyProject.new(project) }
let(:hashed_storage) { Storage::HashedProject.new(project) }
2019-12-26 22:10:19 +05:30
subject(:service) { described_class.new(project: project, old_disk_path: project.disk_path) }
2018-11-18 11:00:15 +05:30
2018-03-17 18:26:18 +05:30
describe '#execute' do
2019-03-02 22:35:43 +05:30
let(:old_disk_path) { legacy_storage.disk_path }
let(:new_disk_path) { hashed_storage.disk_path }
2018-03-17 18:26:18 +05:30
before do
allow(service).to receive(:gitlab_shell) { gitlab_shell }
end
2019-02-15 15:39:39 +05:30
context 'repository lock' do
it 'tries to lock the repository' do
expect(service).to receive(:try_to_set_repository_read_only!)
service.execute
end
it 'fails when a git operation is in progress' do
allow(project).to receive(:repo_reference_count) { 1 }
2019-07-07 11:18:12 +05:30
expect { service.execute }.to raise_error(Projects::HashedStorage::RepositoryInUseError)
end
end
context 'when repository doesnt exist on disk' do
let(:project) { create(:project, :legacy_storage) }
it 'skips the disk change but increase the version' do
service.execute
expect(project.hashed_storage?(:repository)).to be_truthy
2019-02-15 15:39:39 +05:30
end
end
2018-03-17 18:26:18 +05:30
context 'when succeeds' do
it 'renames project and wiki repositories' do
service.execute
2019-12-21 20:55:43 +05:30
expect(gitlab_shell.repository_exists?(project.repository_storage, "#{new_disk_path}.git")).to be_truthy
expect(gitlab_shell.repository_exists?(project.repository_storage, "#{new_disk_path}.wiki.git")).to be_truthy
2018-03-17 18:26:18 +05:30
end
it 'updates project to be hashed and not read-only' do
service.execute
expect(project.hashed_storage?(:repository)).to be_truthy
expect(project.repository_read_only).to be_falsey
end
it 'move operation is called for both repositories' do
2019-03-02 22:35:43 +05:30
expect_move_repository(old_disk_path, new_disk_path)
expect_move_repository("#{old_disk_path}.wiki", "#{new_disk_path}.wiki")
2018-03-17 18:26:18 +05:30
service.execute
end
it 'writes project full path to .git/config' do
service.execute
2018-12-05 23:21:45 +05:30
rugged_config = rugged_repo(project.repository).config['gitlab.fullpath']
2018-11-08 19:23:39 +05:30
expect(rugged_config).to eq project.full_path
2018-03-17 18:26:18 +05:30
end
end
context 'when one move fails' do
it 'rollsback repositories to original name' do
allow(service).to receive(:move_repository).and_call_original
2019-03-02 22:35:43 +05:30
allow(service).to receive(:move_repository).with(old_disk_path, new_disk_path).once { false } # will disable first move only
2018-03-17 18:26:18 +05:30
expect(service).to receive(:rollback_folder_move).and_call_original
service.execute
2019-12-21 20:55:43 +05:30
expect(gitlab_shell.repository_exists?(project.repository_storage, "#{new_disk_path}.git")).to be_falsey
expect(gitlab_shell.repository_exists?(project.repository_storage, "#{new_disk_path}.wiki.git")).to be_falsey
2018-03-17 18:26:18 +05:30
expect(project.repository_read_only?).to be_falsey
end
context 'when rollback fails' do
before do
2019-03-02 22:35:43 +05:30
gitlab_shell.mv_repository(project.repository_storage, old_disk_path, new_disk_path)
2018-03-17 18:26:18 +05:30
end
2019-03-02 22:35:43 +05:30
it 'does not try to move nil repository over existing' do
expect(gitlab_shell).not_to receive(:mv_repository).with(project.repository_storage, old_disk_path, new_disk_path)
expect_move_repository("#{old_disk_path}.wiki", "#{new_disk_path}.wiki")
2018-03-17 18:26:18 +05:30
service.execute
end
end
end
2019-07-07 11:18:12 +05:30
it 'works even when project validation fails' do
allow(project).to receive(:valid?) { false }
expect { service.execute }.to change { project.hashed_storage?(:repository) }.to(true)
end
2018-03-17 18:26:18 +05:30
def expect_move_repository(from_name, to_name)
2018-10-15 14:42:47 +05:30
expect(gitlab_shell).to receive(:mv_repository).with(project.repository_storage, from_name, to_name).and_call_original
2018-03-17 18:26:18 +05:30
end
end
end