feat: IndexedDB based caching for labels, inboxes and teams [CW-50] (#6710)
* feat: allow caching of labels in the account scope * feat: send cache keys in account json response * feat: kickstart web worker * feat: setup basic architecture for workers * feat: install idb * feat: add datamanger * fix: typos * refactor: rename method * feat: make init db a manual step * refactor: separate accountIdFromRoute * feat: cache enabled API client * feat: enable caching for inboxes and labels * feat: enable cache for team * feat: manage exceptions for team * feat: add team to data manager * feat: add a generic listener * refactor: send only cache keys * refactor: separate validate method * feat: add listeners * feat: add event for revalidate * feat: add cache keys endpoint * refactor: fetch cache keys instead of full account data * fix: key pattern * feat: don't fetch account for cache_keys * fix: cache key base class * refactor: cache keys helper * feat: add helper * fix: cache-key update logic * feat: delete indexeddb on logout * feat: remove worker.js * refactor: move data-manager * refactor: name of file * feat: add test for DataManager * refactor: add fake idb to jest setup * test: cache keys helper * test: cache keys helper * test: cache_keys in accounts controller * refactor: remove cache_keys context * feat: add policy for cache-keys
This commit is contained in:
@@ -137,6 +137,22 @@ RSpec.describe 'Accounts API', type: :request do
|
||||
end
|
||||
end
|
||||
|
||||
describe 'GET /api/v1/accounts/{account.id}/cache_keys' do
|
||||
let(:account) { create(:account) }
|
||||
let(:admin) { create(:user, account: account, role: :administrator) }
|
||||
|
||||
it 'returns cache_keys as expected' do
|
||||
account.update(auto_resolve_duration: 30)
|
||||
|
||||
get "/api/v1/accounts/#{account.id}/cache_keys",
|
||||
headers: admin.create_new_auth_token,
|
||||
as: :json
|
||||
|
||||
expect(response).to have_http_status(:success)
|
||||
expect(JSON.parse(response.body)['cache_keys'].keys).to match_array(%w[label inbox team])
|
||||
end
|
||||
end
|
||||
|
||||
describe 'PUT /api/v1/accounts/{account.id}' do
|
||||
let(:account) { create(:account) }
|
||||
let(:agent) { create(:user, account: account, role: :agent) }
|
||||
|
||||
34
spec/helpers/cache_keys_helper_spec.rb
Normal file
34
spec/helpers/cache_keys_helper_spec.rb
Normal file
@@ -0,0 +1,34 @@
|
||||
require 'rails_helper'
|
||||
|
||||
RSpec.describe CacheKeysHelper, type: :helper do
|
||||
let(:account_id) { 1 }
|
||||
let(:key) { 'example_key' }
|
||||
|
||||
describe '#get_prefixed_cache_key' do
|
||||
it 'returns a string with the correct prefix, account ID, and key' do
|
||||
expected_key = "idb-cache-key-account-#{account_id}-#{key}"
|
||||
result = helper.get_prefixed_cache_key(account_id, key)
|
||||
|
||||
expect(result).to eq(expected_key)
|
||||
end
|
||||
end
|
||||
|
||||
describe '#fetch_value_for_key' do
|
||||
it 'returns the zero epoch time if no value is cached' do
|
||||
result = helper.fetch_value_for_key(account_id, 'another-key')
|
||||
|
||||
expect(result).to eq('0000000000')
|
||||
end
|
||||
|
||||
it 'returns a cached value if it exists' do
|
||||
value = Time.now.to_i
|
||||
prefixed_cache_key = helper.get_prefixed_cache_key(account_id, key)
|
||||
|
||||
Redis::Alfred.set(prefixed_cache_key, value)
|
||||
|
||||
result = helper.fetch_value_for_key(account_id, key)
|
||||
|
||||
expect(result).to eq(value.to_s)
|
||||
end
|
||||
end
|
||||
end
|
||||
Reference in New Issue
Block a user