Add mock block tx structs

This commit is contained in:
nolash
2021-04-15 11:15:48 +02:00
parent 908f762cd0
commit b4be9ff04c
3 changed files with 75 additions and 34 deletions

View File

@@ -72,8 +72,8 @@ class Syncer:
self.backend.register_filter(str(f))
def process_single(self, conn, block, tx, block_height, tx_index):
self.backend.set(block_height, tx_index)
def process_single(self, conn, block, tx):
self.backend.set(block.number, tx.index)
self.filter.apply(conn, block, tx)
@@ -133,7 +133,7 @@ class HeadSyncer(BlockPollSyncer):
rcpt = conn.do(receipt(tx.hash))
tx.apply_receipt(rcpt)
self.process_single(conn, block, tx, block.number, i)
self.process_single(conn, block, tx)
i += 1

View File

@@ -0,0 +1,59 @@
# standard imports
import os
# external imports
from hexathon import add_0x
# local imports
from chainsyncer.driver import HistorySyncer
from chainsyncer.error import NoBlockForYou
class MockTx:
def __init__(self, tx_hash, index):
self.hash = tx_hash
self.index = index
class MockBlock:
def __init__(self, number, txs):
self.number = number
self.txs = txs
def tx(self, i):
return MockTx(i, self.txs[i])
class TestSyncer(HistorySyncer):
def __init__(self, backend, tx_counts=[]):
self.tx_counts = tx_counts
super(TestSyncer, self).__init__(backend)
def get(self, conn):
if self.backend.block_height == self.backend.target_block:
self.running = False
raise NoBlockForYou()
if self.backend.block_height > len(self.tx_counts):
return []
block_txs = []
for i in range(self.tx_counts[self.backend.block_height]):
block_txs.append(add_0x(os.urandom(32).hex()))
return MockBlock(self.backend.block_height, block_txs)
def process(self, conn, block):
i = 0
for tx in block.txs:
self.process_single(conn, block, tx)
i += 1
self.backend.set(self.backend.block_height + 1, 0)