From 2dba9188885e71d903c5ce6456a69b00b2826a22 Mon Sep 17 00:00:00 2001 From: "alex.sharov" Date: Mon, 9 Aug 2021 09:46:10 +0700 Subject: [PATCH] subscribe to state changes --- txpool/fetch.go | 1 + txpool/mocks_test.go | 76 ++++++++++++++++++++++++++++++++++++++++++++ txpool/types.go | 1 - 3 files changed, 77 insertions(+), 1 deletion(-) diff --git a/txpool/fetch.go b/txpool/fetch.go index 4ef9cf3dc..5165c1845 100644 --- a/txpool/fetch.go +++ b/txpool/fetch.go @@ -103,6 +103,7 @@ func (f *Fetch) Start() { f.receivePeerLoop(f.sentryClients[i]) }(i) } + go func() { f.stateChangesLoop(f.ctx, nil) }() } func (f *Fetch) receiveMessageLoop(sentryClient sentry.SentryClient) { diff --git a/txpool/mocks_test.go b/txpool/mocks_test.go index d3178604d..1b4ae4343 100644 --- a/txpool/mocks_test.go +++ b/txpool/mocks_test.go @@ -29,6 +29,9 @@ var _ Pool = &PoolMock{} // IdHashKnownFunc: func(hash []byte) bool { // panic("mock out the IdHashKnown method") // }, +// OnNewBlockFunc: func(stateChanges map[string]senderInfo, unwindTxs TxSlots, minedTxs TxSlots, protocolBaseFee uint64, blockBaseFee uint64, blockHeight uint64) error { +// panic("mock out the OnNewBlock method") +// }, // } // // // use mockedPool in code that requires Pool @@ -48,6 +51,9 @@ type PoolMock struct { // IdHashKnownFunc mocks the IdHashKnown method. IdHashKnownFunc func(hash []byte) bool + // OnNewBlockFunc mocks the OnNewBlock method. + OnNewBlockFunc func(stateChanges map[string]senderInfo, unwindTxs TxSlots, minedTxs TxSlots, protocolBaseFee uint64, blockBaseFee uint64, blockHeight uint64) error + // calls tracks calls to the methods. calls struct { // Add holds details about calls to the Add method. @@ -70,11 +76,27 @@ type PoolMock struct { // Hash is the hash argument value. Hash []byte } + // OnNewBlock holds details about calls to the OnNewBlock method. + OnNewBlock []struct { + // StateChanges is the stateChanges argument value. + StateChanges map[string]senderInfo + // UnwindTxs is the unwindTxs argument value. + UnwindTxs TxSlots + // MinedTxs is the minedTxs argument value. + MinedTxs TxSlots + // ProtocolBaseFee is the protocolBaseFee argument value. + ProtocolBaseFee uint64 + // BlockBaseFee is the blockBaseFee argument value. + BlockBaseFee uint64 + // BlockHeight is the blockHeight argument value. + BlockHeight uint64 + } } lockAdd sync.RWMutex lockAddNewGoodPeer sync.RWMutex lockGetRlp sync.RWMutex lockIdHashKnown sync.RWMutex + lockOnNewBlock sync.RWMutex } // Add calls AddFunc. @@ -209,3 +231,57 @@ func (mock *PoolMock) IdHashKnownCalls() []struct { mock.lockIdHashKnown.RUnlock() return calls } + +// OnNewBlock calls OnNewBlockFunc. +func (mock *PoolMock) OnNewBlock(stateChanges map[string]senderInfo, unwindTxs TxSlots, minedTxs TxSlots, protocolBaseFee uint64, blockBaseFee uint64, blockHeight uint64) error { + callInfo := struct { + StateChanges map[string]senderInfo + UnwindTxs TxSlots + MinedTxs TxSlots + ProtocolBaseFee uint64 + BlockBaseFee uint64 + BlockHeight uint64 + }{ + StateChanges: stateChanges, + UnwindTxs: unwindTxs, + MinedTxs: minedTxs, + ProtocolBaseFee: protocolBaseFee, + BlockBaseFee: blockBaseFee, + BlockHeight: blockHeight, + } + mock.lockOnNewBlock.Lock() + mock.calls.OnNewBlock = append(mock.calls.OnNewBlock, callInfo) + mock.lockOnNewBlock.Unlock() + if mock.OnNewBlockFunc == nil { + var ( + errOut error + ) + return errOut + } + return mock.OnNewBlockFunc(stateChanges, unwindTxs, minedTxs, protocolBaseFee, blockBaseFee, blockHeight) +} + +// OnNewBlockCalls gets all the calls that were made to OnNewBlock. +// Check the length with: +// len(mockedPool.OnNewBlockCalls()) +func (mock *PoolMock) OnNewBlockCalls() []struct { + StateChanges map[string]senderInfo + UnwindTxs TxSlots + MinedTxs TxSlots + ProtocolBaseFee uint64 + BlockBaseFee uint64 + BlockHeight uint64 +} { + var calls []struct { + StateChanges map[string]senderInfo + UnwindTxs TxSlots + MinedTxs TxSlots + ProtocolBaseFee uint64 + BlockBaseFee uint64 + BlockHeight uint64 + } + mock.lockOnNewBlock.RLock() + calls = mock.calls.OnNewBlock + mock.lockOnNewBlock.RUnlock() + return calls +} diff --git a/txpool/types.go b/txpool/types.go index 387790b98..5fce74dc1 100644 --- a/txpool/types.go +++ b/txpool/types.go @@ -458,7 +458,6 @@ func DecodeSender(enc []byte) (nonce uint64, balance uint256.Int, err error) { } (&balance).SetBytes(enc[pos+1 : pos+decodeLength+1]) - pos += decodeLength + 1 } return }