diff options
author | GitLab Bot <gitlab-bot@gitlab.com> | 2020-02-10 18:08:54 +0300 |
---|---|---|
committer | GitLab Bot <gitlab-bot@gitlab.com> | 2020-02-10 18:08:54 +0300 |
commit | 11e5d1b9ca3efa7be34ddebb708a6aedb4e91639 (patch) | |
tree | 999fdffb9d3db2e5200994e289e50fa3a3a1684a /spec/models/concerns | |
parent | 7351a484d79236b7e9d47c86f2fcc970b7ae10b0 (diff) |
Add latest changes from gitlab-org/gitlab@master
Diffstat (limited to 'spec/models/concerns')
-rw-r--r-- | spec/models/concerns/reactive_caching_spec.rb | 65 |
1 files changed, 55 insertions, 10 deletions
diff --git a/spec/models/concerns/reactive_caching_spec.rb b/spec/models/concerns/reactive_caching_spec.rb index 4af6906ce2c..6d4eeae641f 100644 --- a/spec/models/concerns/reactive_caching_spec.rb +++ b/spec/models/concerns/reactive_caching_spec.rb @@ -165,11 +165,25 @@ describe ReactiveCaching, :use_clean_rails_memory_store_caching do describe '#exclusively_update_reactive_cache!' do subject(:go!) { instance.exclusively_update_reactive_cache! } + shared_examples 'successful cache' do + it 'caches the result of #calculate_reactive_cache' do + go! + + expect(read_reactive_cache(instance)).to eq(calculation.call) + end + + it 'does not raise the exception' do + expect { go! }.not_to raise_exception(ReactiveCaching::ExceededReactiveCacheLimit) + end + end + context 'when the lease is free and lifetime is not exceeded' do before do - stub_reactive_cache(instance, "preexisting") + stub_reactive_cache(instance, 'preexisting') end + it_behaves_like 'successful cache' + it 'takes and releases the lease' do expect_to_obtain_exclusive_lease(cache_key, 'uuid') expect_to_cancel_exclusive_lease(cache_key, 'uuid') @@ -177,19 +191,13 @@ describe ReactiveCaching, :use_clean_rails_memory_store_caching do go! end - it 'caches the result of #calculate_reactive_cache' do - go! - - expect(read_reactive_cache(instance)).to eq(calculation.call) - end - - it "enqueues a repeat worker" do + it 'enqueues a repeat worker' do expect_reactive_cache_update_queued(instance) go! end - it "calls a reactive_cache_updated only once if content did not change on subsequent update" do + it 'calls a reactive_cache_updated only once if content did not change on subsequent update' do expect(instance).to receive(:calculate_reactive_cache).twice expect(instance).to receive(:reactive_cache_updated).once @@ -202,6 +210,43 @@ describe ReactiveCaching, :use_clean_rails_memory_store_caching do go! end + context 'when calculated object size exceeds default reactive_cache_hard_limit' do + let(:calculation) { -> { 'a' * 2 * 1.megabyte } } + + shared_examples 'ExceededReactiveCacheLimit' do + it 'raises ExceededReactiveCacheLimit exception and does not cache new data' do + expect { go! }.to raise_exception(ReactiveCaching::ExceededReactiveCacheLimit) + + expect(read_reactive_cache(instance)).not_to eq(calculation.call) + end + end + + context 'when reactive_cache_hard_limit feature flag is enabled' do + it_behaves_like 'ExceededReactiveCacheLimit' + + context 'when reactive_cache_hard_limit is overridden' do + let(:test_class) { Class.new(CacheTest) { self.reactive_cache_hard_limit = 3.megabytes } } + let(:instance) { test_class.new(666, &calculation) } + + it_behaves_like 'successful cache' + + context 'when cache size is over the overridden limit' do + let(:calculation) { -> { 'a' * 4 * 1.megabyte } } + + it_behaves_like 'ExceededReactiveCacheLimit' + end + end + end + + context 'when reactive_cache_limit feature flag is disabled' do + before do + stub_feature_flags(reactive_cache_limit: false) + end + + it_behaves_like 'successful cache' + end + end + context 'and #calculate_reactive_cache raises an exception' do before do stub_reactive_cache(instance, "preexisting") @@ -256,8 +301,8 @@ describe ReactiveCaching, :use_clean_rails_memory_store_caching do it { expect(subject.reactive_cache_lease_timeout).to be_a(ActiveSupport::Duration) } it { expect(subject.reactive_cache_refresh_interval).to be_a(ActiveSupport::Duration) } it { expect(subject.reactive_cache_lifetime).to be_a(ActiveSupport::Duration) } - it { expect(subject.reactive_cache_key).to respond_to(:call) } + it { expect(subject.reactive_cache_hard_limit).to be_a(Integer) } it { expect(subject.reactive_cache_worker_finder).to respond_to(:call) } end end |