2020-06-23 12:28:01 -04:00
|
|
|
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-23 12:28:01 -04:00
|
|
|
|
|
|
|
|
2020-06-30 23:13:38 -04:00
|
|
|
def cause_protobuf_stderr():
|
|
|
|
try:
|
|
|
|
Claim.from_bytes(unhexlify(
|
|
|
|
'005a3c63779597cba4c0e6ee45c3074fc389bd564ccc5d4a90eb4baacb0b028f2f4930'
|
|
|
|
'0db003d6a27f0cac8be8b45fdda597303208b81845534e4543494c07123e0a420a'
|
|
|
|
))
|
|
|
|
except DecodeError:
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
2020-06-23 12:28:01 -04:00
|
|
|
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-06-23 12:28:01 -04:00
|
|
|
|
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-23 12:28:01 -04:00
|
|
|
|
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)
|
2020-06-23 12:28:01 -04:00
|
|
|
|
|
|
|
|
|
|
|
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()
|