2020-02-06 18:12:33 +03:00
|
|
|
import asyncio
|
|
|
|
import pytest
|
2020-02-07 03:56:00 +03:00
|
|
|
import time
|
2020-06-17 02:46:51 +03:00
|
|
|
from typing import Dict, Any, List
|
2020-02-07 03:01:18 +03:00
|
|
|
from tests.setup_nodes import setup_full_system
|
2020-04-21 07:29:47 +03:00
|
|
|
from tests.block_tools import BlockTools
|
|
|
|
from src.consensus.constants import constants as consensus_constants
|
2020-06-11 17:56:59 +03:00
|
|
|
from src.util.ints import uint32
|
2020-06-17 02:46:51 +03:00
|
|
|
from src.types.full_block import FullBlock
|
2020-04-21 07:29:47 +03:00
|
|
|
|
|
|
|
bt = BlockTools()
|
|
|
|
test_constants: Dict[str, Any] = consensus_constants.copy()
|
2020-04-30 08:02:35 +03:00
|
|
|
test_constants.update({"DIFFICULTY_STARTING": 500, "MIN_ITERS_STARTING": 500})
|
2020-04-21 07:29:47 +03:00
|
|
|
|
|
|
|
test_constants["GENESIS_BLOCK"] = bytes(
|
|
|
|
bt.create_genesis_block(test_constants, bytes([0] * 32), b"0")
|
|
|
|
)
|
2020-02-06 18:12:33 +03:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture(scope="module")
|
|
|
|
def event_loop():
|
|
|
|
loop = asyncio.get_event_loop()
|
|
|
|
yield loop
|
|
|
|
|
|
|
|
|
|
|
|
class TestSimulation:
|
2020-02-07 03:01:18 +03:00
|
|
|
@pytest.fixture(scope="function")
|
|
|
|
async def simulation(self):
|
2020-04-21 07:29:47 +03:00
|
|
|
async for _ in setup_full_system(test_constants):
|
2020-02-07 03:01:18 +03:00
|
|
|
yield _
|
|
|
|
|
2020-02-06 18:12:33 +03:00
|
|
|
@pytest.mark.asyncio
|
2020-02-07 03:01:18 +03:00
|
|
|
async def test_simulation_1(self, simulation):
|
2020-06-11 23:08:30 +03:00
|
|
|
node1, node2, _, _, _, _, _, _, _ = simulation
|
2020-02-07 03:56:00 +03:00
|
|
|
start = time.time()
|
2020-06-11 17:56:59 +03:00
|
|
|
# Use node2 to test node communication, since only node1 extends the chain.
|
2020-06-17 02:46:51 +03:00
|
|
|
while time.time() - start < 100:
|
2020-06-18 07:11:51 +03:00
|
|
|
if max([h.height for h in node2.blockchain.get_current_tips()]) > 7:
|
2020-06-11 17:56:59 +03:00
|
|
|
break
|
2020-02-07 03:56:00 +03:00
|
|
|
await asyncio.sleep(1)
|
2020-06-17 02:46:51 +03:00
|
|
|
|
2020-06-18 07:11:51 +03:00
|
|
|
if max([h.height for h in node2.blockchain.get_current_tips()]) <= 7:
|
|
|
|
raise Exception("Failed: could not get 7 blocks.")
|
2020-06-11 17:56:59 +03:00
|
|
|
|
|
|
|
# Wait additional 2 minutes to get a compact block.
|
2020-06-18 07:11:51 +03:00
|
|
|
start = time.time()
|
2020-06-17 02:46:51 +03:00
|
|
|
while time.time() - start < 120:
|
2020-06-11 17:56:59 +03:00
|
|
|
max_height = node1.blockchain.lca_block.height
|
|
|
|
for h in range(1, max_height):
|
|
|
|
blocks_1: List[FullBlock] = await node1.block_store.get_blocks_at(
|
|
|
|
[uint32(h)]
|
|
|
|
)
|
|
|
|
blocks_2: List[FullBlock] = await node2.block_store.get_blocks_at(
|
|
|
|
[uint32(h)]
|
|
|
|
)
|
|
|
|
has_compact_1 = False
|
|
|
|
has_compact_2 = False
|
|
|
|
for block in blocks_1:
|
2020-06-17 02:46:51 +03:00
|
|
|
assert block.proof_of_time is not None
|
2020-06-11 17:56:59 +03:00
|
|
|
if block.proof_of_time.witness_type == 0:
|
|
|
|
has_compact_1 = True
|
|
|
|
break
|
|
|
|
for block in blocks_2:
|
2020-06-17 02:46:51 +03:00
|
|
|
assert block.proof_of_time is not None
|
2020-06-11 17:56:59 +03:00
|
|
|
if block.proof_of_time.witness_type == 0:
|
|
|
|
has_compact_2 = True
|
|
|
|
break
|
|
|
|
if has_compact_1 and has_compact_2:
|
|
|
|
return
|
|
|
|
await asyncio.sleep(1)
|
|
|
|
raise Exception("Failed: no block with compact proof of time.")
|