Include the GitLab version in the cache key for Gitlab::JsonCache

parent d0a921b4
...@@ -22,10 +22,10 @@ module Gitlab ...@@ -22,10 +22,10 @@ module Gitlab
expanded_cache_key = [namespace, key].compact expanded_cache_key = [namespace, key].compact
if cache_key_with_version if cache_key_with_version
expanded_cache_key << Rails.version expanded_cache_key << [Gitlab::VERSION, Rails.version]
end end
expanded_cache_key.join(':') expanded_cache_key.flatten.join(':').freeze
end end
def expire(key) def expire(key)
......
...@@ -6,7 +6,7 @@ describe Gitlab::JsonCache do ...@@ -6,7 +6,7 @@ describe Gitlab::JsonCache do
let(:backend) { double('backend').as_null_object } let(:backend) { double('backend').as_null_object }
let(:namespace) { 'geo' } let(:namespace) { 'geo' }
let(:key) { 'foo' } let(:key) { 'foo' }
let(:expanded_key) { "#{namespace}:#{key}:#{Rails.version}" } let(:expanded_key) { "#{namespace}:#{key}:#{Gitlab::VERSION}:#{Rails.version}" }
set(:broadcast_message) { create(:broadcast_message) } set(:broadcast_message) { create(:broadcast_message) }
subject(:cache) { described_class.new(namespace: namespace, backend: backend) } subject(:cache) { described_class.new(namespace: namespace, backend: backend) }
...@@ -35,42 +35,68 @@ describe Gitlab::JsonCache do ...@@ -35,42 +35,68 @@ describe Gitlab::JsonCache do
describe '#cache_key' do describe '#cache_key' do
context 'when namespace is not defined' do context 'when namespace is not defined' do
it 'expands out the key with Rails version' do context 'when cache_key_with_version is true' do
cache = described_class.new(cache_key_with_version: true) it 'expands out the key with GitLab, and Rails versions' do
cache = described_class.new(cache_key_with_version: true)
cache_key = cache.cache_key(key) cache_key = cache.cache_key(key)
expect(cache_key).to eq("#{key}:#{Rails.version}") expect(cache_key).to eq("#{key}:#{Gitlab::VERSION}:#{Rails.version}")
end
end end
end
context 'when cache_key_with_version is true' do context 'when cache_key_with_version is false' do
it 'expands out the key with namespace and Rails version' do it 'returns the key' do
cache = described_class.new(namespace: namespace, cache_key_with_version: true) cache = described_class.new(namespace: nil, cache_key_with_version: false)
cache_key = cache.cache_key(key) cache_key = cache.cache_key(key)
expect(cache_key).to eq("#{namespace}:#{key}:#{Rails.version}") expect(cache_key).to eq(key)
end
end end
end end
context 'when cache_key_with_version is false' do context 'when namespace is nil' do
it 'expands out the key with namespace' do context 'when cache_key_with_version is true' do
cache = described_class.new(namespace: namespace, cache_key_with_version: false) it 'expands out the key with GitLab, and Rails versions' do
cache = described_class.new(cache_key_with_version: true)
cache_key = cache.cache_key(key) cache_key = cache.cache_key(key)
expect(cache_key).to eq("#{namespace}:#{key}") expect(cache_key).to eq("#{key}:#{Gitlab::VERSION}:#{Rails.version}")
end
end
context 'when cache_key_with_version is false' do
it 'returns the key' do
cache = described_class.new(namespace: nil, cache_key_with_version: false)
cache_key = cache.cache_key(key)
expect(cache_key).to eq(key)
end
end end
end end
context 'when namespace is nil, and cache_key_with_version is false' do context 'when namespace is set' do
it 'returns the key' do context 'when cache_key_with_version is true' do
cache = described_class.new(namespace: nil, cache_key_with_version: false) it 'expands out the key with namespace and Rails version' do
cache = described_class.new(namespace: namespace, cache_key_with_version: true)
cache_key = cache.cache_key(key)
cache_key = cache.cache_key(key) expect(cache_key).to eq("#{namespace}:#{key}:#{Gitlab::VERSION}:#{Rails.version}")
end
end
expect(cache_key).to eq(key) context 'when cache_key_with_version is false' do
it 'expands out the key with namespace' do
cache = described_class.new(namespace: namespace, cache_key_with_version: false)
cache_key = cache.cache_key(key)
expect(cache_key).to eq("#{namespace}:#{key}")
end
end 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