From 7f0cc6b0fbc02e55456597629cd7585d2d800aa2 Mon Sep 17 00:00:00 2001 From: wwestgarth Date: Tue, 24 Sep 2024 12:57:31 +0100 Subject: [PATCH] fix: early exit if there are no expand-by-levels in datanode AMM market-depth calc --- core/execution/amm/estimator_test.go | 1 - datanode/service/market_depth_amm.go | 5 +++- datanode/service/market_depth_amm_test.go | 28 +++++++++++++++++++++++ 3 files changed, 32 insertions(+), 2 deletions(-) diff --git a/core/execution/amm/estimator_test.go b/core/execution/amm/estimator_test.go index e9f3e75a0a..f17e136cb7 100644 --- a/core/execution/amm/estimator_test.go +++ b/core/execution/amm/estimator_test.go @@ -294,5 +294,4 @@ func TestEstimateBoundsOneSided(t *testing.T) { assert.True(t, metrics.LiquidationPriceAtLower.IsZero()) assert.True(t, metrics.PositionSizeAtLower.IsZero()) assert.True(t, metrics.LossOnCommitmentAtLower.IsZero()) - } diff --git a/datanode/service/market_depth_amm.go b/datanode/service/market_depth_amm.go index 412bb8fa78..c5c5d06ec3 100644 --- a/datanode/service/market_depth_amm.go +++ b/datanode/service/market_depth_amm.go @@ -233,8 +233,11 @@ func (m *MarketDepth) getReference(ctx context.Context, marketID string) (num.De } func (m *MarketDepth) expandByLevels(pool entities.AMMPool, levels []*level, priceFactor num.Decimal) ([]*types.Order, []bool, error) { - // get positions + if len(levels) == 0 { + return nil, nil, nil + } + // get position pos, err := m.getAMMPosition(pool.MarketID.String(), pool.AmmPartyID.String()) if err != nil { return nil, nil, err diff --git a/datanode/service/market_depth_amm_test.go b/datanode/service/market_depth_amm_test.go index 09fe4610e1..c267d7fa7f 100644 --- a/datanode/service/market_depth_amm_test.go +++ b/datanode/service/market_depth_amm_test.go @@ -472,6 +472,34 @@ func TestFairgroundAMM(t *testing.T) { assert.Equal(t, "12956", mds.service.GetBestAskPrice(marketID).String()) } +func TestAMMDepthOutOfRange(t *testing.T) { + ctx := context.Background() + + cfg := service.MarketDepthConfig{ + AmmFullExpansionPercentage: 200, + AmmEstimatedStepPercentage: 0, + AmmMaxEstimatedSteps: 0, + } + mds := getServiceWithConfig(t, cfg) + defer mds.ctrl.Finish() + + marketID := vgcrypto.RandomHash() + + ensureLiveOrders(t, mds, marketID) + ensureDecimalPlaces(t, mds, 1, 1) + + // set the mid-price to a value no where near the AMM's prices + mds.marketData.EXPECT().GetMarketDataByID(gomock.Any(), gomock.Any()).Times(1).Return(entities.MarketData{MidPrice: num.DecimalFromInt64(10)}, nil) + + // data node is starting from network history, initialise market-depth based on whats aleady there + ensureAMMs(t, mds, marketID) + mds.service.Initialise(ctx) + + assert.Equal(t, 0, int(mds.service.GetTotalAMMVolume(marketID))) + assert.Equal(t, 0, int(mds.service.GetAMMVolume(marketID, true))) + assert.Equal(t, 0, int(mds.service.GetAMMVolume(marketID, false))) +} + func ensureLiveOrders(t *testing.T, mds *MDS, marketID string) { t.Helper() mds.orders.EXPECT().GetLiveOrders(gomock.Any()).Return([]entities.Order{