debian-mirror-gitlab/spec/lib/gitlab/git/object_pool_spec.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

119 lines
3.2 KiB
Ruby
Raw Permalink Normal View History

2019-02-15 15:39:39 +05:30
# frozen_string_literal: true
require 'spec_helper'
2020-07-28 23:09:34 +05:30
RSpec.describe Gitlab::Git::ObjectPool do
2019-02-15 15:39:39 +05:30
let(:pool_repository) { create(:pool_repository) }
let(:source_repository) { pool_repository.source_project.repository }
subject { pool_repository.object_pool }
describe '#storage' do
it "equals the pool repository's shard name" do
expect(subject.storage).not_to be_nil
expect(subject.storage).to eq(pool_repository.shard_name)
end
end
describe '#create' do
before do
2021-01-03 14:25:43 +05:30
subject.create # rubocop:disable Rails/SaveBang
2019-02-15 15:39:39 +05:30
end
context "when the pool doesn't exist yet" do
it 'creates the pool' do
expect(subject.exists?).to be(true)
end
end
context 'when the pool already exists' do
it 'raises an FailedPrecondition' do
expect do
2021-01-03 14:25:43 +05:30
subject.create # rubocop:disable Rails/SaveBang
2019-02-15 15:39:39 +05:30
end.to raise_error(GRPC::FailedPrecondition)
end
end
end
describe '#exists?' do
context "when the object pool doesn't exist" do
it 'returns false' do
expect(subject.exists?).to be(false)
end
end
context 'when the object pool exists' do
let(:pool) { create(:pool_repository, :ready) }
subject { pool.object_pool }
it 'returns true' do
expect(subject.exists?).to be(true)
end
end
end
describe '#link' do
let!(:pool_repository) { create(:pool_repository, :ready) }
context 'when linked for the first time' do
it 'sets a remote' do
expect do
subject.link(source_repository)
end.not_to raise_error
end
end
context 'when the remote is already set' do
before do
subject.link(source_repository)
end
it "doesn't raise an error" do
expect do
subject.link(source_repository)
end.not_to raise_error
end
end
end
2019-07-31 22:56:46 +05:30
describe '#fetch' do
2023-01-13 00:05:48 +05:30
context 'when the object pool repository exists' do
let!(:pool_repository) { create(:pool_repository, :ready) }
2019-07-31 22:56:46 +05:30
2023-01-13 00:05:48 +05:30
context 'without changes' do
it 'does not raise an error' do
expect { subject.fetch }.not_to raise_error
end
2019-07-31 22:56:46 +05:30
end
2023-01-13 00:05:48 +05:30
context 'with new commit in source repository' do
let(:branch_name) { Gitlab::Git::Ref.extract_branch_name(source_repository.root_ref) }
let(:source_ref_name) { "refs/heads/#{branch_name}" }
let(:pool_ref_name) { "refs/remotes/origin/heads/#{branch_name}" }
let(:new_commit_id) do
source_repository.create_file(
pool_repository.source_project.owner,
'a.file',
'This is a file',
branch_name: branch_name,
message: 'Add a file'
)
end
it 'fetches objects from the source repository' do
# Sanity-check that the commit does not yet exist in the pool repository.
expect(subject.repository.commit(new_commit_id)).to be_nil
subject.fetch
expect(subject.repository.commit(pool_ref_name).id).to eq(new_commit_id)
expect(subject.repository.commit_count(pool_ref_name))
.to eq(source_repository.raw_repository.commit_count(source_ref_name))
end
2019-07-31 22:56:46 +05:30
end
end
end
2019-02-15 15:39:39 +05:30
end