test_relays.py 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. import time
  2. from functools import partial
  3. import pytest
  4. import hivemind
  5. async def ping_to_client(dht, node, peer_id: hivemind.p2p.PeerID):
  6. return await node.protocol.call_ping(peer_id)
  7. @pytest.mark.forked
  8. @pytest.mark.parametrize(
  9. "use_auto_relay,use_relay",
  10. [
  11. (True, True),
  12. (False, False),
  13. ],
  14. )
  15. def test_autorelay(use_auto_relay: bool, use_relay: bool):
  16. dht_first_peer = hivemind.DHT(
  17. start=True,
  18. use_auto_relay=use_auto_relay,
  19. use_relay=use_relay,
  20. force_reachability="public",
  21. )
  22. dht_first_peer_id = dht_first_peer.peer_id
  23. initial_peers = dht_first_peer.get_visible_maddrs()
  24. assert dht_first_peer_id is not None
  25. dht_third_peer = hivemind.DHT(
  26. initial_peers=initial_peers,
  27. host_maddrs=[],
  28. start=True,
  29. no_listen=True,
  30. use_relay=use_relay,
  31. client_mode=False,
  32. use_auto_relay=use_auto_relay,
  33. )
  34. dht_second_peer = hivemind.DHT(
  35. initial_peers=initial_peers,
  36. start=True,
  37. client_mode=False,
  38. no_listen=False,
  39. use_relay=use_relay,
  40. use_auto_relay=use_auto_relay,
  41. )
  42. assert dht_first_peer.is_alive() and dht_second_peer.is_alive() and dht_third_peer.is_alive()
  43. reached_ip = dht_second_peer.run_coroutine(partial(ping_to_client, peer_id=dht_third_peer.peer_id))
  44. if reached_ip:
  45. assert use_relay
  46. for peer in dht_first_peer, dht_second_peer, dht_third_peer:
  47. peer.shutdown()