BigW Consortium Gitlab

Commit 00cd5d93 by Jacob Vosmaer (GitLab) Committed by Rémy Coutable

Use Redis cache for branch existence checks

parent 2822254e
...@@ -217,11 +217,7 @@ class Repository ...@@ -217,11 +217,7 @@ class Repository
def branch_exists?(branch_name) def branch_exists?(branch_name)
return false unless raw_repository return false unless raw_repository
@branch_exists_memo ||= Hash.new do |hash, key| branch_names.include?(branch_name)
hash[key] = raw_repository.branch_exists?(key)
end
@branch_exists_memo[branch_name]
end end
def ref_exists?(ref) def ref_exists?(ref)
......
...@@ -1166,6 +1166,31 @@ describe Repository do ...@@ -1166,6 +1166,31 @@ describe Repository do
end end
end end
describe '#branch_exists?' do
it 'uses branch_names' do
allow(repository).to receive(:branch_names).and_return(['foobar'])
expect(repository.branch_exists?('foobar')).to eq(true)
expect(repository.branch_exists?('master')).to eq(false)
end
end
describe '#branch_names', :use_clean_rails_memory_store_caching do
let(:fake_branch_names) { ['foobar'] }
it 'gets cached across Repository instances' do
allow(repository.raw_repository).to receive(:branch_names).once.and_return(fake_branch_names)
expect(repository.branch_names).to eq(fake_branch_names)
fresh_repository = Project.find(project.id).repository
expect(fresh_repository.object_id).not_to eq(repository.object_id)
expect(fresh_repository.raw_repository).not_to receive(:branch_names)
expect(fresh_repository.branch_names).to eq(fake_branch_names)
end
end
describe '#update_autocrlf_option' do describe '#update_autocrlf_option' do
describe 'when autocrlf is not already set to :input' do describe 'when autocrlf is not already set to :input' do
before do before do
......
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