From 0d19bbcf8dc731b848c56f7a400c14beec3c28dc Mon Sep 17 00:00:00 2001 From: Toon Willems Date: Wed, 30 Oct 2024 14:43:47 +0100 Subject: [PATCH] bug(caching) - Add cache key version to Subscriptions::ChargeCacheService (#2756) ## Description If fees were present in the cache they would be duplicated when moving to the new caching scheme. this PR adds a key that we can bump when making changes to the caching. --- app/services/subscriptions/charge_cache_service.rb | 5 +++++ spec/services/invoices/customer_usage_service_spec.rb | 1 + spec/services/subscriptions/charge_cache_service_spec.rb | 4 ++-- 3 files changed, 8 insertions(+), 2 deletions(-) diff --git a/app/services/subscriptions/charge_cache_service.rb b/app/services/subscriptions/charge_cache_service.rb index 0a56e96ff23..9b84b3b1582 100644 --- a/app/services/subscriptions/charge_cache_service.rb +++ b/app/services/subscriptions/charge_cache_service.rb @@ -2,6 +2,8 @@ module Subscriptions class ChargeCacheService + CACHE_KEY_VERSION = '1' + def self.expire_for_subscription(subscription) subscription.plan.charges.includes(:filters) .find_each { expire_for_subscription_charge(subscription:, charge: _1) } @@ -21,9 +23,12 @@ def initialize(subscription:, charge:, charge_filter: nil) @charge_filter = charge_filter end + # IMPORTANT + # when making changes here, please make sure to bump the cache key so old values are immediately invalidated! def cache_key [ 'charge-usage', + CACHE_KEY_VERSION, charge.id, subscription.id, charge.updated_at.iso8601, diff --git a/spec/services/invoices/customer_usage_service_spec.rb b/spec/services/invoices/customer_usage_service_spec.rb index f42fa618cec..e83313ada53 100644 --- a/spec/services/invoices/customer_usage_service_spec.rb +++ b/spec/services/invoices/customer_usage_service_spec.rb @@ -68,6 +68,7 @@ it 'uses the Rails cache' do key = [ 'charge-usage', + Subscriptions::ChargeCacheService::CACHE_KEY_VERSION, charge.id, subscription.id, charge.updated_at.iso8601 diff --git a/spec/services/subscriptions/charge_cache_service_spec.rb b/spec/services/subscriptions/charge_cache_service_spec.rb index 54465e6e5f5..31195d8b3ab 100644 --- a/spec/services/subscriptions/charge_cache_service_spec.rb +++ b/spec/services/subscriptions/charge_cache_service_spec.rb @@ -12,7 +12,7 @@ describe '#cache_key' do it 'returns the cache key' do expect(cache_service.cache_key) - .to eq("charge-usage/#{charge.id}/#{subscription.id}/#{charge.updated_at.iso8601}") + .to eq("charge-usage/#{described_class::CACHE_KEY_VERSION}/#{charge.id}/#{subscription.id}/#{charge.updated_at.iso8601}") end context 'with a charge filter' do @@ -20,7 +20,7 @@ it 'returns the cache key with the charge filter' do expect(cache_service.cache_key) - .to eq("charge-usage/#{charge.id}/#{subscription.id}/#{charge.updated_at.iso8601}/#{charge_filter.id}/#{charge_filter.updated_at.iso8601}") + .to eq("charge-usage/#{described_class::CACHE_KEY_VERSION}/#{charge.id}/#{subscription.id}/#{charge.updated_at.iso8601}/#{charge_filter.id}/#{charge_filter.updated_at.iso8601}") end end end