mirror of
https://gitlab.com/pulsechaincom/erigon-pulse.git
synced 2025-01-19 00:54:12 +00:00
persistence
This commit is contained in:
parent
224d851465
commit
8133abfd56
@ -334,8 +334,7 @@ func (sc *SendersCache) fromDB(tx kv.Tx) error {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
id := binary.BigEndian.Uint64(v)
|
id := binary.BigEndian.Uint64(v)
|
||||||
sc.senderID = id
|
sc.senderIDs[string(k)] = id
|
||||||
sc.senderIDs[string(v)] = id
|
|
||||||
}
|
}
|
||||||
|
|
||||||
c, err = tx.Cursor(kv.PooledSender)
|
c, err = tx.Cursor(kv.PooledSender)
|
||||||
@ -358,11 +357,16 @@ func (sc *SendersCache) fromDB(tx kv.Tx) error {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
sc.blockHeight.Store(binary.BigEndian.Uint64(height))
|
sc.blockHeight.Store(binary.BigEndian.Uint64(height))
|
||||||
|
v, err := tx.GetOne(kv.PoolInfo, []byte("sender_cache_id"))
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
sc.senderID = binary.BigEndian.Uint64(v)
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
var SenderCacheHeightKey = []byte("s")
|
var SenderCacheHeightKey = []byte("sender_cache_heght")
|
||||||
|
|
||||||
func (sc *SendersCache) flush(tx kv.RwTx) error {
|
func (sc *SendersCache) flush(tx kv.RwTx) error {
|
||||||
sc.lock.RLock()
|
sc.lock.RLock()
|
||||||
@ -392,6 +396,11 @@ func (sc *SendersCache) flush(tx kv.RwTx) error {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
binary.BigEndian.PutUint64(encID, sc.senderID)
|
||||||
|
err = tx.Put(kv.PoolInfo, []byte("sender_cache_id"), encID)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
//TODO: flush and evict
|
//TODO: flush and evict
|
||||||
|
|
||||||
@ -771,7 +780,8 @@ func (p *TxPool) fromDB(tx kv.Tx, senders *SendersCache) error {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
txs.txs[i] = &TxSlot{}
|
txs.txs[i] = &TxSlot{}
|
||||||
_, err := parseCtx.ParseTransaction(v, 8+8, txs.txs[i], nil)
|
|
||||||
|
_, err := parseCtx.ParseTransaction(v[8+8:], 0, txs.txs[i], nil)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
@ -534,10 +534,10 @@ func FuzzOnNewBlocks11(f *testing.F) {
|
|||||||
// }
|
// }
|
||||||
//}
|
//}
|
||||||
assert.Equal(sendersCache.senderID, s2.senderID)
|
assert.Equal(sendersCache.senderID, s2.senderID)
|
||||||
//assert.Equal(sendersCache.blockHeight.Load(), s2.blockHeight.Load())
|
assert.Equal(sendersCache.blockHeight.Load(), s2.blockHeight.Load())
|
||||||
//require.Equal(t, len(sendersCache.senderIDs), len(s2.senderIDs))
|
require.Equal(t, len(sendersCache.senderIDs), len(s2.senderIDs))
|
||||||
//require.Equal(t, len(sendersCache.senderInfo), len(s2.senderInfo))
|
require.Equal(t, len(sendersCache.senderInfo), len(s2.senderInfo))
|
||||||
//require.Equal(t, len(pool.byHash), len(p2.byHash))
|
require.Equal(t, len(pool.byHash), len(p2.byHash))
|
||||||
//assert.Equal(pool.pending.Len(), p2.pending.Len())
|
//assert.Equal(pool.pending.Len(), p2.pending.Len())
|
||||||
//assert.Equal(pool.baseFee.Len(), p2.baseFee.Len())
|
//assert.Equal(pool.baseFee.Len(), p2.baseFee.Len())
|
||||||
//assert.Equal(pool.queued.Len(), p2.queued.Len())
|
//assert.Equal(pool.queued.Len(), p2.queued.Len())
|
||||||
|
@ -129,7 +129,6 @@ func (ctx *TxParseContext) ParseTransaction(payload []byte, pos int, slot *TxSlo
|
|||||||
if dataLen > txMaxSize {
|
if dataLen > txMaxSize {
|
||||||
return 0, fmt.Errorf("%s: too large tx.size=%dKb", ParseTransactionErrorPrefix, len(payload)/1024)
|
return 0, fmt.Errorf("%s: too large tx.size=%dKb", ParseTransactionErrorPrefix, len(payload)/1024)
|
||||||
}
|
}
|
||||||
slot.rlp = payload[pos : dataPos+dataLen]
|
|
||||||
|
|
||||||
//if dataPos+dataLen != len(payload) {
|
//if dataPos+dataLen != len(payload) {
|
||||||
// return 0, fmt.Errorf("%s: transaction must be either 1 list or 1 string", ParseTransactionErrorPrefix)
|
// return 0, fmt.Errorf("%s: transaction must be either 1 list or 1 string", ParseTransactionErrorPrefix)
|
||||||
@ -160,6 +159,8 @@ func (ctx *TxParseContext) ParseTransaction(payload []byte, pos int, slot *TxSlo
|
|||||||
}
|
}
|
||||||
p = dataPos
|
p = dataPos
|
||||||
}
|
}
|
||||||
|
slot.rlp = payload[pos : dataPos+dataLen]
|
||||||
|
|
||||||
// Remember where signing hash data begins (it will need to be wrapped in an RLP list)
|
// Remember where signing hash data begins (it will need to be wrapped in an RLP list)
|
||||||
sigHashPos := p
|
sigHashPos := p
|
||||||
// If it is non-legacy tx, chainId follows, but we skip it
|
// If it is non-legacy tx, chainId follows, but we skip it
|
||||||
|
@ -57,6 +57,23 @@ var txParseTests = []struct {
|
|||||||
signHashStr: "35fbc0cd33a181e62b7432338f172106886a1396e1e3647ddf1e756740d81ae1", nonce: 3},
|
signHashStr: "35fbc0cd33a181e62b7432338f172106886a1396e1e3647ddf1e756740d81ae1", nonce: 3},
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestName(t *testing.T) {
|
||||||
|
a1 := decodeHex("02f864010301018261a894b94f5374fce5edbc8e2a8697c15331677e6ebf0b0a825544c001a0c9519f4f2b30335884581971573fadf60c6204f59a911df35ee8a540456b2660a032f1e8e2c5dd761f9e4f88f41c8310aeaba26a8bfcdacfedfa12ec3862d37521")
|
||||||
|
a2 := decodeHex("02e001031419808002940000000000000000000000000000000000000005c0010101")
|
||||||
|
ctx := NewTxParseContext()
|
||||||
|
{
|
||||||
|
tx, txSender := &TxSlot{}, [20]byte{}
|
||||||
|
_, err := ctx.ParseTransaction(a1, 0, tx, txSender[:])
|
||||||
|
require.NoError(t, err)
|
||||||
|
fmt.Printf("%d,%d\n", tx.nonce, tx.tip)
|
||||||
|
}
|
||||||
|
{
|
||||||
|
tx, txSender := &TxSlot{}, [20]byte{}
|
||||||
|
_, err := ctx.ParseTransaction(a2, 0, tx, txSender[:])
|
||||||
|
require.NoError(t, err)
|
||||||
|
fmt.Printf("%d,%d\n", tx.nonce, tx.tip)
|
||||||
|
}
|
||||||
|
}
|
||||||
func TestParseTransactionRLP(t *testing.T) {
|
func TestParseTransactionRLP(t *testing.T) {
|
||||||
ctx := NewTxParseContext()
|
ctx := NewTxParseContext()
|
||||||
for i, tt := range txParseTests {
|
for i, tt := range txParseTests {
|
||||||
|
Loading…
Reference in New Issue
Block a user