From c50784d39a5f9b8a138d883924884ff2d822d454 Mon Sep 17 00:00:00 2001 From: Jonathan Fung <121899091+jonfung-dydx@users.noreply.github.com> Date: Wed, 28 Feb 2024 21:00:00 -0800 Subject: [PATCH] exclude MsgBatchCancel from mempool (#28) --- mempool/clist_mempool_test.go | 4 ++-- mempool/dydx_helpers.go | 6 +++++- 2 files changed, 7 insertions(+), 3 deletions(-) diff --git a/mempool/clist_mempool_test.go b/mempool/clist_mempool_test.go index 3d02ef5316a..89abbdab49b 100644 --- a/mempool/clist_mempool_test.go +++ b/mempool/clist_mempool_test.go @@ -754,7 +754,7 @@ func TestMempoolConcurrentUpdateAndReceiveCheckTxResponse(t *testing.T) { go func(h int) { defer wg.Done() - err := mp.Update(int64(h), []types.Tx{tx}, abciResponses(1, abci.CodeTypeOK), nil, nil) + err := mp.Update(int64(h), time.UnixMilli(1), []types.Tx{tx}, abciResponses(1, abci.CodeTypeOK), nil, nil) require.NoError(t, err) require.Equal(t, int64(h), mp.height.Load(), "height mismatch") }(h) @@ -798,7 +798,7 @@ func TestMempoolNotifyTxsAvailable(t *testing.T) { require.Empty(t, mp.TxsAvailable()) // Updating the pool will remove the tx and set the variable to false - err := mp.Update(1, []types.Tx{tx}, abciResponses(1, abci.CodeTypeOK), nil, nil) + err := mp.Update(1, time.UnixMilli(1), []types.Tx{tx}, abciResponses(1, abci.CodeTypeOK), nil, nil) require.NoError(t, err) require.Zero(t, mp.Size()) require.False(t, mp.notifiedTxsAvailable.Load()) diff --git a/mempool/dydx_helpers.go b/mempool/dydx_helpers.go index 5e22d9aac66..0b284880196 100644 --- a/mempool/dydx_helpers.go +++ b/mempool/dydx_helpers.go @@ -9,7 +9,7 @@ import ( // IsShortTermClobOrderTransaction returns true if the provided `tx` is a // Cosmos transaction containing a short-term `MsgPlaceOrder` or -// short-term `MsgCancelOrder` message. +// short-term `MsgCancelOrder` or `MsgBatchCancel` message. func IsShortTermClobOrderTransaction( tx types.Tx, mempoolLogger log.Logger, @@ -44,6 +44,10 @@ func IsShortTermClobOrderTransaction( } return msgCancelOrder.OrderId.IsShortTermOrder() } + if cosmosTx.Body.Messages[0].TypeUrl == "/dydxprotocol.clob.MsgBatchCancel" { + // MsgBatchCancel only processes short term order cancellations as of right now. + return true + } } return false