Commit ae22b486 authored by Stan Hu's avatar Stan Hu

Merge branch '30439-use-redis-set-cache' into 'master'

Use the redis set cache for branch and tag names

Closes #30439

See merge request gitlab-org/gitlab!17116
parents c05f69ba 83958cfc
...@@ -249,13 +249,13 @@ class Repository ...@@ -249,13 +249,13 @@ class Repository
def branch_exists?(branch_name) def branch_exists?(branch_name)
return false unless raw_repository return false unless raw_repository
branch_names.include?(branch_name) branch_names_include?(branch_name)
end end
def tag_exists?(tag_name) def tag_exists?(tag_name)
return false unless raw_repository return false unless raw_repository
tag_names.include?(tag_name) tag_names_include?(tag_name)
end end
def ref_exists?(ref) def ref_exists?(ref)
...@@ -559,10 +559,10 @@ class Repository ...@@ -559,10 +559,10 @@ class Repository
end end
delegate :branch_names, to: :raw_repository delegate :branch_names, to: :raw_repository
cache_method :branch_names, fallback: [] cache_method_as_redis_set :branch_names, fallback: []
delegate :tag_names, to: :raw_repository delegate :tag_names, to: :raw_repository
cache_method :tag_names, fallback: [] cache_method_as_redis_set :tag_names, fallback: []
delegate :branch_count, :tag_count, :has_visible_content?, to: :raw_repository delegate :branch_count, :tag_count, :has_visible_content?, to: :raw_repository
cache_method :branch_count, fallback: 0 cache_method :branch_count, fallback: 0
......
---
title: Cache branch and tag names as Redis sets
merge_request: 30476
author:
type: performance
...@@ -1223,36 +1223,66 @@ describe Repository do ...@@ -1223,36 +1223,66 @@ describe Repository do
end end
describe '#branch_exists?' do describe '#branch_exists?' do
it 'uses branch_names' do let(:branch) { repository.root_ref }
allow(repository).to receive(:branch_names).and_return(['foobar'])
expect(repository.branch_exists?('foobar')).to eq(true) subject { repository.branch_exists?(branch) }
expect(repository.branch_exists?('master')).to eq(false)
it 'delegates to branch_names when the cache is empty' do
repository.expire_branches_cache
expect(repository).to receive(:branch_names).and_call_original
is_expected.to eq(true)
end
it 'uses redis set caching when the cache is filled' do
repository.branch_names # ensure the branch name cache is filled
expect(repository)
.to receive(:branch_names_include?)
.with(branch)
.and_call_original
is_expected.to eq(true)
end end
end end
describe '#tag_exists?' do describe '#tag_exists?' do
it 'uses tag_names' do let(:tag) { repository.tags.first.name }
allow(repository).to receive(:tag_names).and_return(['foobar'])
subject { repository.tag_exists?(tag) }
it 'delegates to tag_names when the cache is empty' do
repository.expire_tags_cache
expect(repository).to receive(:tag_names).and_call_original
is_expected.to eq(true)
end
it 'uses redis set caching when the cache is filled' do
repository.tag_names # ensure the tag name cache is filled
expect(repository)
.to receive(:tag_names_include?)
.with(tag)
.and_call_original
expect(repository.tag_exists?('foobar')).to eq(true) is_expected.to eq(true)
expect(repository.tag_exists?('master')).to eq(false)
end end
end end
describe '#branch_names', :use_clean_rails_memory_store_caching do describe '#branch_names', :clean_gitlab_redis_cache do
let(:fake_branch_names) { ['foobar'] } let(:fake_branch_names) { ['foobar'] }
it 'gets cached across Repository instances' do it 'gets cached across Repository instances' do
allow(repository.raw_repository).to receive(:branch_names).once.and_return(fake_branch_names) allow(repository.raw_repository).to receive(:branch_names).once.and_return(fake_branch_names)
expect(repository.branch_names).to eq(fake_branch_names) expect(repository.branch_names).to match_array(fake_branch_names)
fresh_repository = Project.find(project.id).repository fresh_repository = Project.find(project.id).repository
expect(fresh_repository.object_id).not_to eq(repository.object_id) expect(fresh_repository.object_id).not_to eq(repository.object_id)
expect(fresh_repository.raw_repository).not_to receive(:branch_names) expect(fresh_repository.raw_repository).not_to receive(:branch_names)
expect(fresh_repository.branch_names).to eq(fake_branch_names) expect(fresh_repository.branch_names).to match_array(fake_branch_names)
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