From 35ecc0a800025ff8cd74ec98902c39a3861fce2b Mon Sep 17 00:00:00 2001 From: Adam Fraser Date: Wed, 27 Nov 2024 18:09:27 -0500 Subject: [PATCH] Fix flaky Candles test (#2619) --- .../__tests__/lib/candles-generator.test.ts | 72 +++++++++++-------- 1 file changed, 41 insertions(+), 31 deletions(-) diff --git a/indexer/services/ender/__tests__/lib/candles-generator.test.ts b/indexer/services/ender/__tests__/lib/candles-generator.test.ts index f20b68354c..8d430ddf42 100644 --- a/indexer/services/ender/__tests__/lib/candles-generator.test.ts +++ b/indexer/services/ender/__tests__/lib/candles-generator.test.ts @@ -485,10 +485,16 @@ describe('candleHelper', () => { const usdVolume: string = Big(existingPrice).times(baseTokenVolume).toString(); const orderbookMidPriceClose = '7500'; const orderbookMidPriceOpen = '8000'; + // Set candle start time to be far in the past to ensure all candles are new + const startTime: IsoString = helpers.calculateNormalizedCandleStartTime( + testConstants.createdDateTime.minus({ minutes: 100 }), + CandleResolution.ONE_MINUTE, + ).toISO(); + await Promise.all( _.map(Object.values(CandleResolution), (resolution: CandleResolution) => { return CandleTable.create({ - startedAt: previousStartedAt, + startedAt: startTime, ticker: testConstants.defaultPerpetualMarket.ticker, resolution, low: existingPrice, @@ -508,7 +514,7 @@ describe('candleHelper', () => { setCachePrice('BTC-USD', '10005'); await OrderbookMidPriceMemoryCache.updateOrderbookMidPrices(); - + // Add two trades for BTC-USD market const publisher: KafkaPublisher = new KafkaPublisher(); publisher.addEvents([ defaultTradeKafkaEvent, @@ -516,32 +522,31 @@ describe('candleHelper', () => { ]); // Create new candles, with trades - await runUpdateCandles(publisher).then(async () => { - - // Verify previous candles have orderbookMidPriceClose updated - const previousExpectedCandles: CandleFromDatabase[] = _.map( - Object.values(CandleResolution), - (resolution: CandleResolution) => { - return { - id: CandleTable.uuid(previousStartedAt, defaultCandle.ticker, resolution), - startedAt: previousStartedAt, - ticker: defaultCandle.ticker, - resolution, - low: existingPrice, - high: existingPrice, - open: existingPrice, - close: existingPrice, - baseTokenVolume, - usdVolume, - trades: existingTrades, - startingOpenInterest, - orderbookMidPriceClose: '10005', - orderbookMidPriceOpen, - }; - }, - ); - await verifyCandlesInPostgres(previousExpectedCandles); - }); + await runUpdateCandles(publisher); + + // Verify previous candles have orderbookMidPriceClose updated + const previousExpectedCandles: CandleFromDatabase[] = _.map( + Object.values(CandleResolution), + (resolution: CandleResolution) => { + return { + id: CandleTable.uuid(startTime, defaultCandle.ticker, resolution), + startedAt: startTime, + ticker: defaultCandle.ticker, + resolution, + low: existingPrice, + high: existingPrice, + open: existingPrice, + close: existingPrice, + baseTokenVolume, + usdVolume, + trades: existingTrades, + startingOpenInterest, + orderbookMidPriceClose: '10005', + orderbookMidPriceOpen, + }; + }, + ); + await verifyCandlesInPostgres(previousExpectedCandles); // Verify new candles were created const expectedCandles: CandleFromDatabase[] = _.map( @@ -583,11 +588,16 @@ describe('candleHelper', () => { const usdVolume: string = Big(existingPrice).times(baseTokenVolume).toString(); const orderbookMidPriceClose = '7500'; const orderbookMidPriceOpen = '8000'; + // Set candle start time to be far in the past to ensure all candles are new + const startTime: IsoString = helpers.calculateNormalizedCandleStartTime( + testConstants.createdDateTime.minus({ minutes: 100 }), + CandleResolution.ONE_MINUTE, + ).toISO(); await Promise.all( _.map(Object.values(CandleResolution), (resolution: CandleResolution) => { return CandleTable.create({ - startedAt: previousStartedAt, + startedAt: startTime, ticker: testConstants.defaultPerpetualMarket.ticker, resolution, low: existingPrice, @@ -619,8 +629,8 @@ describe('candleHelper', () => { Object.values(CandleResolution), (resolution: CandleResolution) => { return { - id: CandleTable.uuid(previousStartedAt, defaultCandle.ticker, resolution), - startedAt: previousStartedAt, + id: CandleTable.uuid(startTime, defaultCandle.ticker, resolution), + startedAt: startTime, ticker: defaultCandle.ticker, resolution, low: existingPrice,