2019-07-27 18:41:16 +08:00
|
|
|
import asyncio
|
|
|
|
|
|
|
|
import pytest
|
|
|
|
|
2019-08-01 00:09:09 +08:00
|
|
|
from tests.configs import LISTEN_MADDR
|
2019-07-27 18:41:16 +08:00
|
|
|
|
2019-08-01 00:09:09 +08:00
|
|
|
from .configs import GOSSIPSUB_PARAMS
|
|
|
|
from .factories import FloodsubFactory, GossipsubFactory, HostFactory, PubsubFactory
|
2019-07-27 18:41:16 +08:00
|
|
|
|
|
|
|
|
|
|
|
# pylint: disable=redefined-outer-name
|
|
|
|
|
2019-08-01 06:00:12 +08:00
|
|
|
|
2019-07-27 18:41:16 +08:00
|
|
|
@pytest.fixture
|
|
|
|
def num_hosts():
|
|
|
|
return 3
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture
|
|
|
|
async def hosts(num_hosts):
|
2019-08-01 00:09:09 +08:00
|
|
|
_hosts = HostFactory.create_batch(num_hosts)
|
2019-08-01 06:00:12 +08:00
|
|
|
await asyncio.gather(
|
|
|
|
*[_host.get_network().listen(LISTEN_MADDR) for _host in _hosts]
|
|
|
|
)
|
2019-07-27 18:41:16 +08:00
|
|
|
yield _hosts
|
|
|
|
# Clean up
|
2019-07-28 18:07:48 +08:00
|
|
|
listeners = []
|
2019-07-27 18:41:16 +08:00
|
|
|
for _host in _hosts:
|
|
|
|
for listener in _host.get_network().listeners.values():
|
|
|
|
listener.server.close()
|
2019-07-28 18:07:48 +08:00
|
|
|
listeners.append(listener)
|
2019-08-01 06:00:12 +08:00
|
|
|
await asyncio.gather(*[listener.server.wait_closed() for listener in listeners])
|
2019-07-27 18:41:16 +08:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture
|
|
|
|
def floodsubs(num_hosts):
|
2019-08-01 00:09:09 +08:00
|
|
|
return FloodsubFactory.create_batch(num_hosts)
|
2019-07-27 18:41:16 +08:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture
|
|
|
|
def gossipsub_params():
|
2019-08-01 00:09:09 +08:00
|
|
|
return GOSSIPSUB_PARAMS
|
2019-07-27 18:41:16 +08:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture
|
|
|
|
def gossipsubs(num_hosts, gossipsub_params):
|
2019-08-01 00:09:09 +08:00
|
|
|
yield GossipsubFactory.create_batch(num_hosts, **gossipsub_params._asdict())
|
2019-07-27 18:41:16 +08:00
|
|
|
# TODO: Clean up
|
|
|
|
|
|
|
|
|
2019-08-01 00:09:09 +08:00
|
|
|
def _make_pubsubs(hosts, pubsub_routers, cache_size):
|
2019-07-27 18:41:16 +08:00
|
|
|
if len(pubsub_routers) != len(hosts):
|
|
|
|
raise ValueError(
|
2019-07-31 16:23:07 +08:00
|
|
|
f"lenght of pubsub_routers={pubsub_routers} should be equaled to the "
|
|
|
|
f"length of hosts={len(hosts)}"
|
2019-07-27 18:41:16 +08:00
|
|
|
)
|
|
|
|
return tuple(
|
2019-08-01 00:09:09 +08:00
|
|
|
PubsubFactory(host=host, router=router, cache_size=cache_size)
|
2019-07-27 18:41:16 +08:00
|
|
|
for host, router in zip(hosts, pubsub_routers)
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture
|
2019-08-01 00:09:09 +08:00
|
|
|
def pubsub_cache_size():
|
|
|
|
return None # default
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture
|
|
|
|
def pubsubs_fsub(hosts, floodsubs, pubsub_cache_size):
|
|
|
|
_pubsubs_fsub = _make_pubsubs(hosts, floodsubs, pubsub_cache_size)
|
2019-07-31 16:07:48 +08:00
|
|
|
yield _pubsubs_fsub
|
2019-07-27 18:41:16 +08:00
|
|
|
# TODO: Clean up
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture
|
2019-08-01 00:09:09 +08:00
|
|
|
def pubsubs_gsub(hosts, gossipsubs, pubsub_cache_size):
|
|
|
|
_pubsubs_gsub = _make_pubsubs(hosts, gossipsubs, pubsub_cache_size)
|
2019-07-27 18:41:16 +08:00
|
|
|
yield _pubsubs_gsub
|
|
|
|
# TODO: Clean up
|