2019-10-25 02:10:45 +08:00
|
|
|
"""
|
|
|
|
Test Notify and Notifee by ensuring that the proper events get called, and that
|
|
|
|
the stream passed into opened_stream is correct.
|
2019-03-01 08:08:13 +08:00
|
|
|
|
|
|
|
Note: Listen event does not get hit because MyNotifee is passed
|
|
|
|
into network after network has already started listening
|
|
|
|
|
2019-09-17 21:54:20 +08:00
|
|
|
TODO: Add tests for closed_stream, listen_close when those
|
2019-03-01 08:17:11 +08:00
|
|
|
features are implemented in swarm
|
2019-03-01 08:08:13 +08:00
|
|
|
"""
|
2019-03-01 08:17:11 +08:00
|
|
|
|
2019-09-17 21:54:20 +08:00
|
|
|
import asyncio
|
|
|
|
import enum
|
|
|
|
|
2019-08-03 13:36:19 +08:00
|
|
|
import pytest
|
2019-03-03 20:54:04 +08:00
|
|
|
|
2019-10-28 19:38:43 +08:00
|
|
|
from libp2p.crypto.rsa import create_new_key_pair
|
2019-08-03 13:36:19 +08:00
|
|
|
from libp2p.network.notifee_interface import INotifee
|
2019-09-17 21:54:20 +08:00
|
|
|
from tests.configs import LISTEN_MADDR
|
|
|
|
from tests.factories import SwarmFactory
|
|
|
|
from tests.utils import connect_swarm
|
|
|
|
|
2019-09-06 17:26:40 +08:00
|
|
|
|
2019-09-17 21:54:20 +08:00
|
|
|
class Event(enum.Enum):
|
|
|
|
OpenedStream = 0
|
|
|
|
ClosedStream = 1 # Not implemented
|
|
|
|
Connected = 2
|
|
|
|
Disconnected = 3
|
|
|
|
Listen = 4
|
|
|
|
ListenClose = 5 # Not implemented
|
2019-03-03 20:54:04 +08:00
|
|
|
|
|
|
|
|
2019-03-01 08:08:13 +08:00
|
|
|
class MyNotifee(INotifee):
|
2019-09-17 21:54:20 +08:00
|
|
|
def __init__(self, events):
|
2019-03-01 08:08:13 +08:00
|
|
|
self.events = events
|
|
|
|
|
2019-03-01 08:11:04 +08:00
|
|
|
async def opened_stream(self, network, stream):
|
2019-09-17 21:54:20 +08:00
|
|
|
self.events.append(Event.OpenedStream)
|
2019-03-01 08:08:13 +08:00
|
|
|
|
2019-03-01 08:11:04 +08:00
|
|
|
async def closed_stream(self, network, stream):
|
2019-09-17 21:54:20 +08:00
|
|
|
# TODO: It is not implemented yet.
|
2019-03-01 08:08:13 +08:00
|
|
|
pass
|
|
|
|
|
2019-03-01 08:11:04 +08:00
|
|
|
async def connected(self, network, conn):
|
2019-09-17 21:54:20 +08:00
|
|
|
self.events.append(Event.Connected)
|
2019-03-01 08:08:13 +08:00
|
|
|
|
2019-03-01 08:11:04 +08:00
|
|
|
async def disconnected(self, network, conn):
|
2019-09-17 21:54:20 +08:00
|
|
|
self.events.append(Event.Disconnected)
|
2019-03-01 08:08:13 +08:00
|
|
|
|
2019-03-18 09:30:56 +08:00
|
|
|
async def listen(self, network, _multiaddr):
|
2019-09-17 21:54:20 +08:00
|
|
|
self.events.append(Event.Listen)
|
2019-03-01 08:08:13 +08:00
|
|
|
|
2019-03-18 09:30:56 +08:00
|
|
|
async def listen_close(self, network, _multiaddr):
|
2019-09-17 21:54:20 +08:00
|
|
|
# TODO: It is not implemented yet.
|
2019-03-01 08:08:13 +08:00
|
|
|
pass
|
|
|
|
|
2019-03-24 01:52:02 +08:00
|
|
|
|
2019-03-15 02:01:59 +08:00
|
|
|
@pytest.mark.asyncio
|
2019-09-17 21:54:20 +08:00
|
|
|
async def test_notify(is_host_secure):
|
2019-10-28 19:38:43 +08:00
|
|
|
swarms = [SwarmFactory(is_host_secure, create_new_key_pair()) for _ in range(2)]
|
2019-09-17 21:54:20 +08:00
|
|
|
|
|
|
|
events_0_0 = []
|
|
|
|
events_1_0 = []
|
|
|
|
events_0_without_listen = []
|
|
|
|
swarms[0].register_notifee(MyNotifee(events_0_0))
|
|
|
|
swarms[1].register_notifee(MyNotifee(events_1_0))
|
|
|
|
# Listen
|
|
|
|
await asyncio.gather(*[swarm.listen(LISTEN_MADDR) for swarm in swarms])
|
|
|
|
|
|
|
|
swarms[0].register_notifee(MyNotifee(events_0_without_listen))
|
|
|
|
|
|
|
|
# Connected
|
|
|
|
await connect_swarm(swarms[0], swarms[1])
|
|
|
|
# OpenedStream: first
|
|
|
|
await swarms[0].new_stream(swarms[1].get_peer_id())
|
|
|
|
# OpenedStream: second
|
|
|
|
await swarms[0].new_stream(swarms[1].get_peer_id())
|
|
|
|
# OpenedStream: third, but different direction.
|
|
|
|
await swarms[1].new_stream(swarms[0].get_peer_id())
|
|
|
|
|
|
|
|
await asyncio.sleep(0.01)
|
|
|
|
|
|
|
|
# TODO: Check `ClosedStream` and `ListenClose` events after they are ready.
|
|
|
|
|
|
|
|
# Disconnected
|
|
|
|
await swarms[0].close_peer(swarms[1].get_peer_id())
|
|
|
|
await asyncio.sleep(0.01)
|
|
|
|
|
|
|
|
# Connected again, but different direction.
|
|
|
|
await connect_swarm(swarms[1], swarms[0])
|
|
|
|
await asyncio.sleep(0.01)
|
|
|
|
|
|
|
|
# Disconnected again, but different direction.
|
|
|
|
await swarms[1].close_peer(swarms[0].get_peer_id())
|
|
|
|
await asyncio.sleep(0.01)
|
|
|
|
|
|
|
|
expected_events_without_listen = [
|
|
|
|
Event.Connected,
|
|
|
|
Event.OpenedStream,
|
|
|
|
Event.OpenedStream,
|
|
|
|
Event.OpenedStream,
|
|
|
|
Event.Disconnected,
|
|
|
|
Event.Connected,
|
|
|
|
Event.Disconnected,
|
|
|
|
]
|
|
|
|
expected_events = [Event.Listen] + expected_events_without_listen
|
|
|
|
|
|
|
|
assert events_0_0 == expected_events
|
|
|
|
assert events_1_0 == expected_events
|
|
|
|
assert events_0_without_listen == expected_events_without_listen
|
|
|
|
|
|
|
|
# Clean up
|
|
|
|
await asyncio.gather(*[swarm.close() for swarm in swarms])
|