diff options
| author | Aldo Cortesi <aldo@nullcube.com> | 2016-06-03 11:47:07 +1200 | 
|---|---|---|
| committer | Aldo Cortesi <aldo@nullcube.com> | 2016-06-03 11:47:07 +1200 | 
| commit | c5076f5e019b73ec2f6efea5a4bafed90423df8f (patch) | |
| tree | cf8bcd7ee0da0be6e7a5b3ae673ecc323b0af66c | |
| parent | c6d15904f3e3a54690637990525da0b53ff1e299 (diff) | |
| download | mitmproxy-c5076f5e019b73ec2f6efea5a4bafed90423df8f.tar.gz mitmproxy-c5076f5e019b73ec2f6efea5a4bafed90423df8f.tar.bz2 mitmproxy-c5076f5e019b73ec2f6efea5a4bafed90423df8f.zip | |
Implement a service connection handler counter, use it in Pathod test suite
Lots of failures, but that's a good thing.
| -rw-r--r-- | netlib/tcp.py | 35 | ||||
| -rw-r--r-- | pathod/test.py | 15 | ||||
| -rw-r--r-- | test/pathod/tutils.py | 1 | 
3 files changed, 44 insertions, 7 deletions
| diff --git a/netlib/tcp.py b/netlib/tcp.py index 914aa701..bb0c93a9 100644 --- a/netlib/tcp.py +++ b/netlib/tcp.py @@ -833,6 +833,25 @@ class BaseHandler(_Connection):              return b"" +class Counter: +    def __init__(self): +        self._count = 0 +        self._lock = threading.Lock() + +    @property +    def count(self): +        with self._lock: +            return self._count + +    def __enter__(self): +        with self._lock: +            self._count += 1 + +    def __exit__(self, *args): +        with self._lock: +            self._count -= 1 + +  class TCPServer(object):      request_queue_size = 20 @@ -845,15 +864,17 @@ class TCPServer(object):          self.socket.bind(self.address())          self.address = Address.wrap(self.socket.getsockname())          self.socket.listen(self.request_queue_size) +        self.counter = Counter()      def connection_thread(self, connection, client_address): -        client_address = Address(client_address) -        try: -            self.handle_client_connection(connection, client_address) -        except: -            self.handle_error(connection, client_address) -        finally: -            close_socket(connection) +        with self.counter: +            client_address = Address(client_address) +            try: +                self.handle_client_connection(connection, client_address) +            except: +                self.handle_error(connection, client_address) +            finally: +                close_socket(connection)      def serve_forever(self, poll_interval=0.1):          self.__is_shut_down.clear() diff --git a/pathod/test.py b/pathod/test.py index 32b37731..b10e9229 100644 --- a/pathod/test.py +++ b/pathod/test.py @@ -7,6 +7,10 @@ from six.moves import queue  from . import pathod +class TimeoutError(Exception): +    pass + +  class Daemon:      IFACE = "127.0.0.1" @@ -40,6 +44,17 @@ class Daemon:      def text_log(self):          return self.logfp.getvalue() +    def wait_for_silence(self, timeout=5): +        start = time.time() +        while 1: +            if time.time() - start >= timeout: +                raise TimeoutError( +                    "%s service threads still alive" % +                    self.thread.server.counter.count +                ) +            if self.thread.server.counter.count == 0: +                return +      def expect_log(self, n, timeout=5):          l = []          start = time.time() diff --git a/test/pathod/tutils.py b/test/pathod/tutils.py index a99a2fd3..e674812b 100644 --- a/test/pathod/tutils.py +++ b/test/pathod/tutils.py @@ -64,6 +64,7 @@ class DaemonTests(object):          shutil.rmtree(cls.confdir)      def teardown(self): +        self.d.wait_for_silence()          if not (self.noweb or self.noapi):              self.d.clear_log() | 
