lbry-sdk/scripts/simulate_sync_console.py

107 lines
3.6 KiB
Python
Raw Normal View History

import asyncio
2020-07-11 18:18:33 -04:00
import argparse
2020-06-26 21:52:01 -04:00
from typing import List
2020-06-30 23:13:38 -04:00
from binascii import unhexlify
from google.protobuf.message import DecodeError
2020-07-11 18:18:33 -04:00
from lbry import Config, Ledger, FullNode
2020-06-26 21:52:01 -04:00
from lbry.console import Advanced, Basic
2020-07-11 18:18:33 -04:00
from lbry.schema.claim import Claim
2020-07-29 00:14:40 -04:00
from lbry.testcase import EventGenerator
2020-08-07 20:45:52 -04:00
from lbry.blockchain.sync import BlockchainSync
2020-06-30 23:13:38 -04:00
def cause_protobuf_stderr():
try:
Claim.from_bytes(unhexlify(
'005a3c63779597cba4c0e6ee45c3074fc389bd564ccc5d4a90eb4baacb0b028f2f4930'
'0db003d6a27f0cac8be8b45fdda597303208b81845534e4543494c07123e0a420a'
))
except DecodeError:
pass
class Simulator:
2020-06-26 21:52:01 -04:00
def __init__(self, console):
self.console = console
self.sync = console.service.sync
self.progress = self.sync._on_progress_controller
2020-07-29 00:14:40 -04:00
self.workers = console.service.db.workers
2020-07-11 18:18:33 -04:00
@staticmethod
2020-08-07 20:45:52 -04:00
def block_file_events(start, end, files, txs):
return [
(0, 191, 280, ((100, 0), (191, 280))),
(1, 89, 178, ((89, 178),)),
(2, 73, 86, ((73, 86),)),
(3, 73, 86, ((73, 86),)),
(4, 73, 86, ((73, 86),)),
(5, 73, 86, ((73, 86),)),
]
def claim_events(self, initial_sync: bool, start: int, end: int, total: int):
if initial_sync:
blocks = (end - start) + 1
blocks_step = int(blocks/self.workers)
done = claims_step = int(total/self.workers)
for i in range(0, blocks, blocks_step):
yield i, min(i+blocks_step, blocks), min(done, total), BlockchainSync.CLAIM_FLUSH_SIZE
done += claims_step
else:
yield start, end, total, BlockchainSync.CLAIM_FLUSH_SIZE
def support_events(self, initial_sync: bool, start: int, end: int, total: int):
if initial_sync:
blocks = (end - start) + 1
blocks_step = int(blocks/self.workers)
done = support_step = int(total/self.workers)
for i in range(0, blocks, blocks_step):
yield i, min(i+blocks_step, blocks), min(done, total), BlockchainSync.SUPPORT_FLUSH_SIZE
done += support_step
else:
yield start, end, total, BlockchainSync.SUPPORT_FLUSH_SIZE
async def advance(self, initial_sync: bool, start: int, end: int, files: List[int], txs: int):
txs = txs
claims = int(txs/4)
supports = int(txs/2)
2020-07-29 00:14:40 -04:00
eg = EventGenerator(
initial_sync=initial_sync,
2020-08-07 20:45:52 -04:00
start=start, end=end,
block_files=list(self.block_file_events(start, end, files, txs)),
claims=list(self.claim_events(initial_sync, start, end, claims)),
supports=list(self.support_events(initial_sync, start, end, supports)),
2020-07-29 00:14:40 -04:00
)
for event in eg.events:
await self.progress.add(event)
await asyncio.sleep(0.5)
2020-06-26 21:52:01 -04:00
2020-07-11 18:18:33 -04:00
async def main(console):
2020-06-26 21:52:01 -04:00
sim = Simulator(console)
2020-08-07 20:45:52 -04:00
await sim.advance(True, 0, 10_000, [1, 2, 3, 4, 5], 10_000)
await sim.advance(False, 10_001, 10_101, [5], 5000)
await sim.advance(False, 10_102, 10_102, [5], 200)
if __name__ == "__main__":
2020-07-11 18:18:33 -04:00
parser = argparse.ArgumentParser()
parser.add_argument("--basic", default=False, action="store_true")
2020-08-07 20:45:52 -04:00
parser.add_argument("--workers", default=5)
2020-07-11 18:18:33 -04:00
args = parser.parse_args()
node = FullNode(Ledger(Config(
2020-07-29 00:14:40 -04:00
workers=args.workers,
2020-07-11 18:18:33 -04:00
spv_address_filters=False
)))
2020-08-07 20:45:52 -04:00
console_instance = Basic(node) if args.basic else Advanced(node)
2020-07-11 18:18:33 -04:00
try:
2020-08-07 20:45:52 -04:00
console_instance.starting()
asyncio.run(main(console_instance))
2020-07-11 18:18:33 -04:00
except KeyboardInterrupt:
pass
finally:
2020-08-07 20:45:52 -04:00
console_instance.stopping()