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 /netlib | |
| 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.
Diffstat (limited to 'netlib')
| -rw-r--r-- | netlib/tcp.py | 35 | 
1 files changed, 28 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() | 
