From 64fa5e0738bd10f8a2c0810c130d6001738615b5 Mon Sep 17 00:00:00 2001 From: Adam Fraser Date: Mon, 9 Dec 2024 14:55:39 -0500 Subject: [PATCH] Increase orderbook mid price cache duration to 60 seconds --- .../__tests__/caches/orderbook-mid-prices-cache.test.ts | 4 ++-- .../redis/src/scripts/add_orderbook_mid_prices.lua | 8 ++++---- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/indexer/packages/redis/__tests__/caches/orderbook-mid-prices-cache.test.ts b/indexer/packages/redis/__tests__/caches/orderbook-mid-prices-cache.test.ts index 339611ae749..4ea457764c8 100644 --- a/indexer/packages/redis/__tests__/caches/orderbook-mid-prices-cache.test.ts +++ b/indexer/packages/redis/__tests__/caches/orderbook-mid-prices-cache.test.ts @@ -136,7 +136,7 @@ describe('orderbook-mid-prices-cache', () => { expect(result).toEqual({ 'BTC-USD': '50500' }); }); - it('returns the correct median price after 30 seconds', async () => { + it('returns the correct median price after 60 seconds', async () => { jest.useFakeTimers(); // Mock the getOrderBookMidPrice function for the ticker const mockPrices: string[] = ['50000', '51000', '49000', '48000', '52000', '53000']; @@ -154,7 +154,7 @@ describe('orderbook-mid-prices-cache', () => { expect(OrderbookLevelsCache.getOrderBookMidPrice).toHaveBeenCalledTimes(2); // Advance time and fetch more prices - jest.advanceTimersByTime(31000); // Advance time by 31 seconds + jest.advanceTimersByTime(61000); // Advance time by 61 seconds await fetchAndCacheOrderbookMidPrices( client, [defaultTicker, defaultTicker, defaultTicker, defaultTicker], diff --git a/indexer/packages/redis/src/scripts/add_orderbook_mid_prices.lua b/indexer/packages/redis/src/scripts/add_orderbook_mid_prices.lua index 63590b3e056..c30880fff46 100644 --- a/indexer/packages/redis/src/scripts/add_orderbook_mid_prices.lua +++ b/indexer/packages/redis/src/scripts/add_orderbook_mid_prices.lua @@ -7,8 +7,8 @@ local numArgs = #ARGV -- Get the timestamp from the last argument local timestamp = tonumber(ARGV[numArgs]) --- Time window (30 seconds) -local thirtySeconds = 30 +-- Time window (60 seconds) +local sixtySeconds = 60 -- Validate the timestamp if not timestamp then @@ -16,7 +16,7 @@ if not timestamp then end -- Calculate the cutoff time for removing old prices -local cutoffTime = timestamp - thirtySeconds +local cutoffTime = timestamp - sixtySeconds -- Iterate through each key (market) and corresponding price for i = 1, numKeys do @@ -31,7 +31,7 @@ for i = 1, numKeys do -- Add the price to the sorted set with the current timestamp as the score redis.call("ZADD", priceCacheKey, timestamp, price) - -- Remove entries older than the cutoff time (older than 30 seconds) + -- Remove entries older than the cutoff time (older than 60 seconds) redis.call("ZREMRANGEBYSCORE", priceCacheKey, "-inf", cutoffTime) end