fix tests

This commit is contained in:
Brian Warner 2018-02-21 00:38:19 -08:00
parent 37a7ed7adc
commit 9ae2307a72
2 changed files with 64 additions and 46 deletions

View File

@ -8,27 +8,59 @@ from ..cli import cli
from ..transit import allocate_tcp_port from ..transit import allocate_tcp_port
from wormhole_mailbox_server.server import make_server from wormhole_mailbox_server.server import make_server
from wormhole_mailbox_server.web import make_web_server from wormhole_mailbox_server.web import make_web_server
from wormhole_mailbox_server.database import create_channel_db from wormhole_mailbox_server.database import create_channel_db, create_usage_db
from wormhole_transit_relay.transit_server import Transit from wormhole_transit_relay.transit_server import Transit
class ServerBase: class MyInternetService(service.Service, object):
def setUp(self): # like StreamServerEndpointService, but you can retrieve the port
self._setup_relay(None) def __init__(self, endpoint, factory):
self.endpoint = endpoint
self.factory = factory
self._port_d = defer.Deferred()
self._lp = None
def startService(self):
super(MyInternetService, self).startService()
d = self.endpoint.listen(self.factory)
def good(lp):
self._lp = lp
self._port_d.callback(lp.getHost().port)
def bad(f):
log.err(f)
self._port_d.errback(f)
d.addCallbacks(good, bad)
@defer.inlineCallbacks
def stopService(self):
if self._lp:
yield self._lp.stopListening()
def getPort(self): # only call once!
return self._port_d
class ServerBase:
@defer.inlineCallbacks
def setUp(self):
yield self._setup_relay(None)
@defer.inlineCallbacks
def _setup_relay(self, error, advertise_version=None): def _setup_relay(self, error, advertise_version=None):
self.sp = service.MultiService() self.sp = service.MultiService()
self.sp.startService() self.sp.startService()
# need to talk to twisted team about only using unicode in # need to talk to twisted team about only using unicode in
# endpoints.serverFromString # endpoints.serverFromString
db = create_channel_db(":memory:") db = create_channel_db(":memory:")
self._usage_db = create_usage_db(":memory:")
self._rendezvous = make_server(db, self._rendezvous = make_server(db,
advertise_version=advertise_version, advertise_version=advertise_version,
signal_error=error) signal_error=error,
usage_db=self._usage_db)
ep = endpoints.TCP4ServerEndpoint(reactor, 0, interface="127.0.01") ep = endpoints.TCP4ServerEndpoint(reactor, 0, interface="127.0.01")
site = make_web_server(self._rendezvous, log_requests=False) site = make_web_server(self._rendezvous, log_requests=False)
s = internet.StreamServerEndpointService(ep, site) #self._lp = yield ep.listen(site)
s = MyInternetService(ep, site)
s.setServiceParent(self.sp) s.setServiceParent(self.sp)
self.rdv_ws_port = s.__lp.getHost().port self.rdv_ws_port = yield s.getPort()
self._relay_server = s self._relay_server = s
#self._rendezvous = s._rendezvous #self._rendezvous = s._rendezvous
self.relayurl = u"ws://127.0.0.1:%d/v1" % self.rdv_ws_port self.relayurl = u"ws://127.0.0.1:%d/v1" % self.rdv_ws_port
@ -43,6 +75,7 @@ class ServerBase:
internet.StreamServerEndpointService(ep, f).setServiceParent(self.sp) internet.StreamServerEndpointService(ep, f).setServiceParent(self.sp)
self.transit = u"tcp:127.0.0.1:%d" % self.transitport self.transit = u"tcp:127.0.0.1:%d" % self.transitport
@defer.inlineCallbacks
def tearDown(self): def tearDown(self):
# Unit tests that spawn a (blocking) client in a thread might still # Unit tests that spawn a (blocking) client in a thread might still
# have threads running at this point, if one is stuck waiting for a # have threads running at this point, if one is stuck waiting for a
@ -54,34 +87,27 @@ class ServerBase:
# XXX FIXME there's something in _noclobber test that's not # XXX FIXME there's something in _noclobber test that's not
# waiting for a close, I think -- was pretty relieably getting # waiting for a close, I think -- was pretty relieably getting
# unclean-reactor, but adding a slight pause here stops it... # unclean-reactor, but adding a slight pause here stops it...
from twisted.internet import reactor
tp = reactor.getThreadPool() tp = reactor.getThreadPool()
if not tp.working: if not tp.working:
d = defer.succeed(None) yield self.sp.stopService()
d.addCallback(lambda _: self.sp.stopService()) yield task.deferLater(reactor, 0.1, lambda: None)
d.addCallback(lambda _: task.deferLater(reactor, 0.1, lambda: None)) defer.returnValue(None)
return d
return self.sp.stopService()
# disconnect all callers # disconnect all callers
d = defer.maybeDeferred(self.sp.stopService) d = defer.maybeDeferred(self.sp.stopService)
wait_d = defer.Deferred()
# wait a second, then check to see if it worked # wait a second, then check to see if it worked
reactor.callLater(1.0, wait_d.callback, None) yield task.deferLater(reactor, 1.0, lambda: None)
def _later(res): if len(tp.working):
if len(tp.working): log.msg("wormhole.test.common.ServerBase.tearDown:"
log.msg("wormhole.test.common.ServerBase.tearDown:" " I was unable to convince all threads to exit.")
" I was unable to convince all threads to exit.") tp.dumpStats()
tp.dumpStats() print("tearDown warning: threads are still active")
print("tearDown warning: threads are still active") print("This test will probably hang until one of the"
print("This test will probably hang until one of the" " clients gives up of their own accord.")
" clients gives up of their own accord.") else:
else: log.msg("wormhole.test.common.ServerBase.tearDown:"
log.msg("wormhole.test.common.ServerBase.tearDown:" " I convinced all threads to exit.")
" I convinced all threads to exit.") yield d
return d
wait_d.addCallback(_later)
return wait_d
def config(*argv): def config(*argv):
r = CliRunner() r = CliRunner()

View File

@ -562,7 +562,7 @@ class PregeneratedCode(ServerBase, ScriptsBase, unittest.TestCase):
yield gatherResults([send_d, receive_d], True) yield gatherResults([send_d, receive_d], True)
if fake_tor: if fake_tor:
expected_endpoints = [("127.0.0.1", self.relayport)] expected_endpoints = [("127.0.0.1", self.rdv_ws_port)]
if mode in ("file", "directory"): if mode in ("file", "directory"):
expected_endpoints.append(("127.0.0.1", self.transitport)) expected_endpoints.append(("127.0.0.1", self.transitport))
tx_timing = mtx_tm.call_args[1]["timing"] tx_timing = mtx_tm.call_args[1]["timing"]
@ -665,9 +665,6 @@ class PregeneratedCode(ServerBase, ScriptsBase, unittest.TestCase):
self.failUnlessEqual(modes[i], self.failUnlessEqual(modes[i],
stat.S_IMODE(os.stat(fn).st_mode)) stat.S_IMODE(os.stat(fn).st_mode))
# check server stats
self._rendezvous.get_stats()
def test_text(self): def test_text(self):
return self._do_test() return self._do_test()
def test_text_subprocess(self): def test_text_subprocess(self):
@ -847,9 +844,6 @@ class PregeneratedCode(ServerBase, ScriptsBase, unittest.TestCase):
with open(fn, "r") as f: with open(fn, "r") as f:
self.failUnlessEqual(f.read(), PRESERVE) self.failUnlessEqual(f.read(), PRESERVE)
# check server stats
self._rendezvous.get_stats()
def test_fail_file_noclobber(self): def test_fail_file_noclobber(self):
return self._do_test_fail("file", "noclobber") return self._do_test_fail("file", "noclobber")
def test_fail_directory_noclobber(self): def test_fail_directory_noclobber(self):
@ -913,12 +907,10 @@ class ZeroMode(ServerBase, unittest.TestCase):
self.assertEqual(receive_stdout, message+NL) self.assertEqual(receive_stdout, message+NL)
self.assertEqual(receive_stderr, "") self.assertEqual(receive_stderr, "")
# check server stats
self._rendezvous.get_stats()
class NotWelcome(ServerBase, unittest.TestCase): class NotWelcome(ServerBase, unittest.TestCase):
@inlineCallbacks
def setUp(self): def setUp(self):
self._setup_relay(error="please upgrade XYZ") yield self._setup_relay(error="please upgrade XYZ")
self.cfg = cfg = config("send") self.cfg = cfg = config("send")
cfg.hide_progress = True cfg.hide_progress = True
cfg.listen = False cfg.listen = False
@ -947,7 +939,7 @@ class NotWelcome(ServerBase, unittest.TestCase):
class NoServer(ServerBase, unittest.TestCase): class NoServer(ServerBase, unittest.TestCase):
@inlineCallbacks @inlineCallbacks
def setUp(self): def setUp(self):
self._setup_relay(None) yield self._setup_relay(None)
yield self._relay_server.disownServiceParent() yield self._relay_server.disownServiceParent()
@inlineCallbacks @inlineCallbacks
@ -1091,8 +1083,9 @@ class ExtractFile(unittest.TestCase):
self.assertIn("malicious zipfile", str(e)) self.assertIn("malicious zipfile", str(e))
class AppID(ServerBase, unittest.TestCase): class AppID(ServerBase, unittest.TestCase):
@inlineCallbacks
def setUp(self): def setUp(self):
d = super(AppID, self).setUp() yield super(AppID, self).setUp()
self.cfg = cfg = config("send") self.cfg = cfg = config("send")
# common options for all tests in this suite # common options for all tests in this suite
cfg.hide_progress = True cfg.hide_progress = True
@ -1100,7 +1093,6 @@ class AppID(ServerBase, unittest.TestCase):
cfg.transit_helper = "" cfg.transit_helper = ""
cfg.stdout = io.StringIO() cfg.stdout = io.StringIO()
cfg.stderr = io.StringIO() cfg.stderr = io.StringIO()
return d
@inlineCallbacks @inlineCallbacks
def test_override(self): def test_override(self):
@ -1115,9 +1107,9 @@ class AppID(ServerBase, unittest.TestCase):
yield send_d yield send_d
yield receive_d yield receive_d
used = self._rendezvous._db.execute("SELECT DISTINCT `app_id`" used = self._usage_db.execute("SELECT DISTINCT `app_id`"
" FROM `nameplate_usage`" " FROM `nameplates`"
).fetchall() ).fetchall()
self.assertEqual(len(used), 1, used) self.assertEqual(len(used), 1, used)
self.assertEqual(used[0]["app_id"], u"appid2") self.assertEqual(used[0]["app_id"], u"appid2")