dilate.test_connect: basic integration test
This mocks out the mailbox connection, and makes sure that endpoints are constructed.
This commit is contained in:
parent
059338a257
commit
7f03adda3a
73
src/wormhole/test/dilate/test_connect.py
Normal file
73
src/wormhole/test/dilate/test_connect.py
Normal file
|
@ -0,0 +1,73 @@
|
|||
import re
|
||||
import mock
|
||||
from twisted.internet import reactor
|
||||
from twisted.trial import unittest
|
||||
from twisted.internet.task import Cooperator
|
||||
from twisted.internet.defer import inlineCallbacks
|
||||
from zope.interface import implementer
|
||||
|
||||
from ... import _interfaces
|
||||
from ...eventual import EventualQueue
|
||||
from ..._dilation import manager
|
||||
|
||||
|
||||
@implementer(_interfaces.ISend)
|
||||
class MySend(object):
|
||||
def __init__(self, side):
|
||||
self.rx_phase = 0
|
||||
self.side = side
|
||||
def send(self, phase, plaintext):
|
||||
#print("SEND[%s]" % self.side, phase, plaintext)
|
||||
self.peer.got(phase, plaintext)
|
||||
def got(self, phase, plaintext):
|
||||
d_mo = re.search(r'^dilate-(\d+)$', phase)
|
||||
p = int(d_mo.group(1))
|
||||
assert p == self.rx_phase
|
||||
self.rx_phase += 1
|
||||
self.dilator.received_dilate(plaintext)
|
||||
|
||||
class Connect(unittest.TestCase):
|
||||
@inlineCallbacks
|
||||
def test1(self):
|
||||
#print()
|
||||
send_left = MySend("left")
|
||||
send_right = MySend("right")
|
||||
send_left.peer = send_right
|
||||
send_right.peer = send_left
|
||||
key = b"\x00"*32
|
||||
eq = EventualQueue(reactor)
|
||||
cooperator = Cooperator(scheduler=eq.eventually)
|
||||
|
||||
d_left = manager.Dilator(reactor, eq, cooperator, no_listen=True)
|
||||
d_left.wire(send_left)
|
||||
d_left.got_key(key)
|
||||
d_left.got_wormhole_versions({"can-dilate": ["1"]})
|
||||
send_left.dilator = d_left
|
||||
|
||||
d_right = manager.Dilator(reactor, eq, cooperator)
|
||||
d_right.wire(send_right)
|
||||
d_right.got_key(key)
|
||||
d_right.got_wormhole_versions({"can-dilate": ["1"]})
|
||||
send_right.dilator = d_right
|
||||
|
||||
with mock.patch("wormhole._dilation.connector.ipaddrs.find_addresses",
|
||||
return_value=["127.0.0.1"]):
|
||||
eps_left_d = d_left.dilate()
|
||||
eps_right_d = d_right.dilate()
|
||||
|
||||
eps_left = yield eps_left_d
|
||||
eps_right = yield eps_right_d
|
||||
|
||||
#print("left connected", eps_left)
|
||||
#print("right connected", eps_right)
|
||||
|
||||
control_ep_left, connect_ep_left, listen_ep_left = eps_left
|
||||
control_ep_right, connect_ep_right, listen_ep_right = eps_right
|
||||
|
||||
#control_ep_left.connect(
|
||||
|
||||
# we shut down with w.close(), which calls Dilator.stop(), which
|
||||
# calls manager.stop()
|
||||
yield d_left.stop()
|
||||
yield d_right.stop()
|
||||
|
Loading…
Reference in New Issue
Block a user