Commit b08582f9 authored by Luke Duncalfe's avatar Luke Duncalfe Committed by Peter Leitzen

Remove redundant :wiki_repo traits from projects

The `:wiki_repo` trait initialises an empty wiki repository, however,
`Backup::Repositories` skips dumping empty repositories so this trait
does not affect the tests.
parent 8ede953e
...@@ -17,23 +17,33 @@ RSpec.describe Backup::Repositories do ...@@ -17,23 +17,33 @@ RSpec.describe Backup::Repositories do
end end
describe '#dump' do describe '#dump' do
before do let_it_be(:projects) { create_list(:project, 5, :repository) }
allow(Gitlab.config.repositories.storages).to receive(:keys).and_return(storage_keys)
end
let_it_be(:projects) { create_list(:project, 5, :repository, :wiki_repo) }
let(:storage_keys) { %w[default test_second_storage] } RSpec.shared_examples 'creates repository bundles' do
specify :aggregate_failures do
# Add data to the wiki repository, so it will be included in the dump.
create(:wiki_page, container: project)
context 'no concurrency' do
it 'creates repository bundle' do
subject.dump(max_concurrency: 1, max_storage_concurrency: 1) subject.dump(max_concurrency: 1, max_storage_concurrency: 1)
projects.each do |project| expect(File).to exist(File.join(Gitlab.config.backup.path, 'repositories', project.disk_path + '.bundle'))
expect(File).to exist(File.join(Gitlab.config.backup.path, 'repositories', project.disk_path + '.bundle')) expect(File).to exist(File.join(Gitlab.config.backup.path, 'repositories', project.disk_path + '.wiki' + '.bundle'))
end
end end
end
context 'hashed storage' do
let_it_be(:project) { create(:project, :repository) }
it_behaves_like 'creates repository bundles'
end
context 'legacy storage' do
let_it_be(:project) { create(:project, :repository, :legacy_storage) }
it_behaves_like 'creates repository bundles'
end
context 'no concurrency' do
it 'creates the expected number of threads' do it 'creates the expected number of threads' do
expect(Thread).not_to receive(:new) expect(Thread).not_to receive(:new)
...@@ -63,26 +73,22 @@ RSpec.describe Backup::Repositories do ...@@ -63,26 +73,22 @@ RSpec.describe Backup::Repositories do
subject.dump(max_concurrency: 1, max_storage_concurrency: 1) subject.dump(max_concurrency: 1, max_storage_concurrency: 1)
end.count end.count
create_list(:project, 2, :repository, :wiki_repo) create_list(:project, 2, :repository)
expect do expect do
subject.dump(max_concurrency: 1, max_storage_concurrency: 1) subject.dump(max_concurrency: 1, max_storage_concurrency: 1)
end.not_to exceed_query_limit(control_count) end.not_to exceed_query_limit(control_count)
end end
context 'legacy storage' do
let_it_be(:project) { create(:project, :repository, :legacy_storage, :wiki_repo) }
it 'creates repository bundle' do
subject.dump(max_concurrency: 1, max_storage_concurrency: 1)
expect(File).to exist(File.join(Gitlab.config.backup.path, 'repositories', project.disk_path + '.bundle'))
end
end
end end
[4, 10].each do |max_storage_concurrency| [4, 10].each do |max_storage_concurrency|
context "max_storage_concurrency #{max_storage_concurrency}", quarantine: 'https://gitlab.com/gitlab-org/gitlab/-/issues/241701' do context "max_storage_concurrency #{max_storage_concurrency}", quarantine: 'https://gitlab.com/gitlab-org/gitlab/-/issues/241701' do
let(:storage_keys) { %w[default test_second_storage] }
before do
allow(Gitlab.config.repositories.storages).to receive(:keys).and_return(storage_keys)
end
it 'creates the expected number of threads' do it 'creates the expected number of threads' do
expect(Thread).to receive(:new) expect(Thread).to receive(:new)
.exactly(storage_keys.length * (max_storage_concurrency + 1)).times .exactly(storage_keys.length * (max_storage_concurrency + 1)).times
...@@ -135,7 +141,7 @@ RSpec.describe Backup::Repositories do ...@@ -135,7 +141,7 @@ RSpec.describe Backup::Repositories do
subject.dump(max_concurrency: 1, max_storage_concurrency: max_storage_concurrency) subject.dump(max_concurrency: 1, max_storage_concurrency: max_storage_concurrency)
end.count end.count
create_list(:project, 2, :repository, :wiki_repo) create_list(:project, 2, :repository)
expect do expect do
subject.dump(max_concurrency: 1, max_storage_concurrency: max_storage_concurrency) subject.dump(max_concurrency: 1, max_storage_concurrency: max_storage_concurrency)
...@@ -146,7 +152,25 @@ RSpec.describe Backup::Repositories do ...@@ -146,7 +152,25 @@ RSpec.describe Backup::Repositories do
end end
describe '#restore' do describe '#restore' do
let_it_be(:project) { create(:project, :wiki_repo) } let_it_be(:project) { create(:project) }
it 'restores repositories from bundles', :aggregate_failures do
next_path_to_bundle = [
Rails.root.join('spec/fixtures/lib/backup/project_repo.bundle'),
Rails.root.join('spec/fixtures/lib/backup/wiki_repo.bundle')
].to_enum
allow_next_instance_of(described_class::BackupRestore) do |backup_restore|
allow(backup_restore).to receive(:path_to_bundle).and_return(next_path_to_bundle.next)
end
subject.restore
collect_commit_shas = -> (repo) { repo.commits('master', limit: 10).map(&:sha) }
expect(collect_commit_shas.call(project.repository)).to eq(['393a7d860a5a4c3cc736d7eb00604e3472bb95ec'])
expect(collect_commit_shas.call(project.wiki.repository)).to eq(['c74b9948d0088d703ee1fafeddd9ed9add2901ea'])
end
describe 'command failure' do describe 'command failure' do
before do before do
......
...@@ -325,11 +325,12 @@ RSpec.describe 'gitlab:app namespace rake task', :delete do ...@@ -325,11 +325,12 @@ RSpec.describe 'gitlab:app namespace rake task', :delete do
end end
let!(:project_a) { create(:project, :repository) } let!(:project_a) { create(:project, :repository) }
let!(:project_a_wiki_page) { create(:wiki_page, container: project_a) }
let!(:project_b) { create(:project, :repository, repository_storage: 'test_second_storage') } let!(:project_b) { create(:project, :repository, repository_storage: 'test_second_storage') }
let!(:b_storage_dir) { File.join(test_second_storage_dir, File.dirname(project_b.disk_path)) } let!(:b_storage_dir) { File.join(test_second_storage_dir, File.dirname(project_b.disk_path)) }
context 'no concurrency' do shared_examples 'includes repositories in all repository storages' do
it 'includes repositories in all repository storages' do specify :aggregate_failures do
expect { run_rake_task('gitlab:backup:create') }.to output.to_stdout expect { run_rake_task('gitlab:backup:create') }.to output.to_stdout
tar_contents, exit_status = Gitlab::Popen.popen( tar_contents, exit_status = Gitlab::Popen.popen(
...@@ -337,27 +338,24 @@ RSpec.describe 'gitlab:app namespace rake task', :delete do ...@@ -337,27 +338,24 @@ RSpec.describe 'gitlab:app namespace rake task', :delete do
) )
expect(exit_status).to eq(0) expect(exit_status).to eq(0)
expect(tar_contents).to match("repositories/#{project_a.disk_path}.bundle") expect(tar_contents).to include(
expect(tar_contents).to match("repositories/#{project_b.disk_path}.bundle") "repositories/#{project_a.disk_path}.bundle",
"repositories/#{project_a.disk_path}.wiki.bundle",
"repositories/#{project_b.disk_path}.bundle"
)
end end
end end
context 'no concurrency' do
it_behaves_like 'includes repositories in all repository storages'
end
context 'with concurrency' do context 'with concurrency' do
before do before do
stub_env('GITLAB_BACKUP_MAX_CONCURRENCY', 4) stub_env('GITLAB_BACKUP_MAX_CONCURRENCY', 4)
end end
it 'includes repositories in all repository storages' do it_behaves_like 'includes repositories in all repository storages'
expect { run_rake_task('gitlab:backup:create') }.to output.to_stdout
tar_contents, exit_status = Gitlab::Popen.popen(
%W{tar -tvf #{backup_tar} repositories}
)
expect(exit_status).to eq(0)
expect(tar_contents).to match("repositories/#{project_a.disk_path}.bundle")
expect(tar_contents).to match("repositories/#{project_b.disk_path}.bundle")
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