2022-04-24 20:19:39 +00:00
|
|
|
import os, uuid
|
|
|
|
from queue import Empty
|
2022-05-01 05:45:26 +00:00
|
|
|
TEST_DIR = 'testdata/%s-%s' % (str(uuid.uuid4())[:6], os.path.basename(__file__)) + '/'
|
2022-04-24 20:19:39 +00:00
|
|
|
print("Test directory:", TEST_DIR)
|
|
|
|
os.environ["ONIONR_HOME"] = TEST_DIR
|
|
|
|
|
|
|
|
from time import sleep
|
|
|
|
from threading import Thread
|
|
|
|
import asyncio
|
|
|
|
import unittest
|
|
|
|
import sys
|
|
|
|
sys.path.append(".")
|
|
|
|
sys.path.append("src/")
|
|
|
|
|
|
|
|
from ordered_set import OrderedSet
|
|
|
|
import onionrblocks
|
|
|
|
|
|
|
|
import blockdb
|
|
|
|
from gossip.server import gossip_server
|
|
|
|
from gossip.blockqueues import gossip_block_queues
|
|
|
|
from filepaths import gossip_server_socket_file
|
|
|
|
|
|
|
|
|
|
|
|
BLOCK_MAX_SIZE = 1024 * 2000
|
|
|
|
BLOCK_MAX_SIZE_LEN = len(str(BLOCK_MAX_SIZE))
|
|
|
|
BLOCK_ID_SIZE = 128
|
|
|
|
BLOCK_STREAM_OFFSET_DIGITS = 8
|
|
|
|
|
|
|
|
|
|
|
|
class OnionrServerPutBlockTest(unittest.TestCase):
|
|
|
|
|
|
|
|
|
|
|
|
def test_put_block(self):
|
|
|
|
|
|
|
|
Thread(target=gossip_server, daemon=True).start()
|
|
|
|
sleep(0.01)
|
|
|
|
|
|
|
|
bl = onionrblocks.blockcreator.create_anonvdf_block(
|
|
|
|
b"my test block", b"txt", 2800)
|
|
|
|
|
|
|
|
async def block_put_client():
|
|
|
|
reader, writer = await asyncio.open_unix_connection(
|
|
|
|
gossip_server_socket_file)
|
|
|
|
writer.write(int(5).to_bytes(1, 'big'))
|
|
|
|
await writer.drain()
|
|
|
|
|
|
|
|
writer.write(bl.id)
|
|
|
|
writer.write(
|
|
|
|
str(len(bl.raw)).zfill(BLOCK_MAX_SIZE_LEN).encode('utf-8'))
|
|
|
|
writer.write(bl.raw)
|
|
|
|
await writer.drain()
|
|
|
|
|
|
|
|
sleep(0.03)
|
|
|
|
try:
|
|
|
|
self.assertEqual(gossip_block_queues[0].get_nowait().raw, bl.raw)
|
|
|
|
except Empty:
|
|
|
|
self.assertEqual(gossip_block_queues[1].get_nowait().raw, bl.raw)
|
|
|
|
|
|
|
|
|
|
|
|
asyncio.run(block_put_client())
|
|
|
|
|
|
|
|
unittest.main()
|