chia-blockchain/tests/test_simulation.py

72 lines
2.6 KiB
Python
Raw Normal View History

2020-02-06 18:12:33 +03:00
import asyncio
import pytest
2020-02-07 03:56:00 +03:00
import time
from typing import Dict, Any, List
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
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()
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:
@pytest.fixture(scope="function")
async def simulation(self):
2020-04-21 07:29:47 +03:00
async for _ in setup_full_system(test_constants):
yield _
2020-02-06 18:12:33 +03:00
@pytest.mark.asyncio
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.
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-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()
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:
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:
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.")