2018-06-15 17:32:37 +00:00
|
|
|
require 'spec_helper'
|
|
|
|
|
|
|
|
describe Projects::BatchOpenIssuesCountService do
|
|
|
|
let!(:project_1) { create(:project) }
|
|
|
|
let!(:project_2) { create(:project) }
|
|
|
|
|
|
|
|
let(:subject) { described_class.new([project_1, project_2]) }
|
|
|
|
|
|
|
|
context '#refresh_cache', :use_clean_rails_memory_store_caching do
|
|
|
|
before do
|
|
|
|
create(:issue, project: project_1)
|
|
|
|
create(:issue, project: project_1, confidential: true)
|
|
|
|
|
|
|
|
create(:issue, project: project_2)
|
|
|
|
create(:issue, project: project_2, confidential: true)
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when cache is clean' do
|
|
|
|
it 'refreshes cache keys correctly' do
|
|
|
|
subject.refresh_cache
|
|
|
|
|
2018-06-22 17:17:03 +00:00
|
|
|
# It does not update total issues cache
|
|
|
|
expect(Rails.cache.read(get_cache_key(subject, project_1))).to eq(nil)
|
|
|
|
expect(Rails.cache.read(get_cache_key(subject, project_2))).to eq(nil)
|
|
|
|
|
2018-06-15 17:32:37 +00:00
|
|
|
expect(Rails.cache.read(get_cache_key(subject, project_1, true))).to eq(1)
|
|
|
|
expect(Rails.cache.read(get_cache_key(subject, project_1, true))).to eq(1)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when issues count is already cached' do
|
|
|
|
before do
|
|
|
|
create(:issue, project: project_2)
|
|
|
|
subject.refresh_cache
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'does update cache again' do
|
|
|
|
expect(Rails.cache).not_to receive(:write)
|
|
|
|
|
|
|
|
subject.refresh_cache
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def get_cache_key(subject, project, public_key = false)
|
|
|
|
service = subject.count_service.new(project)
|
|
|
|
|
|
|
|
if public_key
|
|
|
|
service.cache_key(service.class::PUBLIC_COUNT_KEY)
|
|
|
|
else
|
|
|
|
service.cache_key(service.class::TOTAL_COUNT_KEY)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|