From 2135e3200cd9032e0604b6682e144cbb2b3d6cdf Mon Sep 17 00:00:00 2001 From: "alex.sharov" Date: Sat, 28 Aug 2021 15:11:54 +0700 Subject: [PATCH] add state check assert routine --- txpool/pool.go | 25 +++++++++++++++++++++++++ 1 file changed, 25 insertions(+) diff --git a/txpool/pool.go b/txpool/pool.go index f88ee3932..52d2bd6bc 100644 --- a/txpool/pool.go +++ b/txpool/pool.go @@ -627,6 +627,31 @@ func (sc *SendersCache) flush(tx kv.RwTx, byNonce *ByNonce, sendersWithoutTransa } } fmt.Printf("justDeleted:%d, justInserted:%d\n", justDeleted, justInserted) + if ASSERT { + { + duplicates := map[string]uint64{} + _ = tx.ForPrefix(kv.PooledSenderIDToAdress, nil, func(k, v []byte) error { + id, ok := duplicates[string(v)] + if ok { + fmt.Printf("duplicate: %d,%d,%x\n", id, binary.BigEndian.Uint64(k), string(v)) + panic(1) + } + return nil + }) + } + { + duplicates := map[uint64]string{} + _ = tx.ForPrefix(kv.PooledSenderIDToAdress, nil, func(k, v []byte) error { + id := binary.BigEndian.Uint64(v) + addr, ok := duplicates[id] + if ok { + fmt.Printf("duplicate: %x,%x,%d\n", addr, k, binary.BigEndian.Uint64(v)) + panic(1) + } + return nil + }) + } + } if ASSERT { _ = tx.ForEach(kv.PooledTransaction, nil, func(k, v []byte) error { vv, err := tx.GetOne(kv.PooledSenderIDToAdress, v[:8])