from twisted.application import service from twisted.internet import reactor, defer from twisted.python import log from txwormhole.transit import allocate_tcp_port from wormhole_server.server import RelayServer from wormhole import __version__ class ServerBase: def setUp(self): self.sp = service.MultiService() self.sp.startService() relayport = allocate_tcp_port() transitport = allocate_tcp_port() s = RelayServer("tcp:%d:interface=127.0.0.1" % relayport, "tcp:%s:interface=127.0.0.1" % transitport, __version__) s.setServiceParent(self.sp) self._rendezvous = s._rendezvous self._transit_server = s._transit self.relayurl = u"http://127.0.0.1:%d/wormhole-relay/" % relayport self.rdv_ws_url = self.relayurl.replace("http:", "ws:") + "ws" self.rdv_ws_port = relayport # ws://127.0.0.1:%d/wormhole-relay/ws self.transit = u"tcp:127.0.0.1:%d" % transitport def tearDown(self): # 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 # message from a companion which has exited with an error. Our # relay's .stopService() drops all connections, which ought to # encourage those threads to terminate soon. If they don't, print a # warning to ease debugging. tp = reactor.getThreadPool() if not tp.working: return self.sp.stopService() # disconnect all callers d = defer.maybeDeferred(self.sp.stopService) wait_d = defer.Deferred() # wait a second, then check to see if it worked reactor.callLater(1.0, wait_d.callback, None) def _later(res): if len(tp.working): log.msg("wormhole.test.common.ServerBase.tearDown:" " I was unable to convince all threads to exit.") tp.dumpStats() print("tearDown warning: threads are still active") print("This test will probably hang until one of the" " clients gives up of their own accord.") else: log.msg("wormhole.test.common.ServerBase.tearDown:" " I convinced all threads to exit.") return d wait_d.addCallback(_later) return wait_d