diff options
| author | Yury Selivanov <yury@magic.io> | 2016-06-08 12:33:31 -0400 | 
|---|---|---|
| committer | Yury Selivanov <yury@magic.io> | 2016-06-08 12:33:31 -0400 | 
| commit | f1c6fa986647791977d974bd43119b46a7a3cdbc (patch) | |
| tree | 191f22cd29bf8bdf269be09fd14ff5a7f7cbf660 /Lib/asyncio/selector_events.py | |
| parent | 7d7a11b5d700c54260c517d0fb57fe1caf591e31 (diff) | |
| download | cpython-git-f1c6fa986647791977d974bd43119b46a7a3cdbc.tar.gz | |
Issue #27136: Fix DNS static resolution; don't use it in getaddrinfo
Patch by A. Jesse Jiryu Davis
Diffstat (limited to 'Lib/asyncio/selector_events.py')
| -rw-r--r-- | Lib/asyncio/selector_events.py | 24 | 
1 files changed, 14 insertions, 10 deletions
| diff --git a/Lib/asyncio/selector_events.py b/Lib/asyncio/selector_events.py index b34fee34df..fb7ab2108e 100644 --- a/Lib/asyncio/selector_events.py +++ b/Lib/asyncio/selector_events.py @@ -385,24 +385,28 @@ class BaseSelectorEventLoop(base_events.BaseEventLoop):      def sock_connect(self, sock, address):          """Connect to a remote socket at address. -        The address must be already resolved to avoid the trap of hanging the -        entire event loop when the address requires doing a DNS lookup. For -        example, it must be an IP address, not a hostname, for AF_INET and -        AF_INET6 address families. Use getaddrinfo() to resolve the hostname -        asynchronously. -          This method is a coroutine.          """          if self._debug and sock.gettimeout() != 0:              raise ValueError("the socket must be non-blocking") +          fut = self.create_future() +        if hasattr(socket, 'AF_UNIX') and sock.family == socket.AF_UNIX: +            self._sock_connect(fut, sock, address) +        else: +            resolved = base_events._ensure_resolved(address, loop=self) +            resolved.add_done_callback( +                lambda resolved: self._on_resolved(fut, sock, resolved)) + +        return fut + +    def _on_resolved(self, fut, sock, resolved):          try: -            base_events._check_resolved_address(sock, address) -        except ValueError as err: -            fut.set_exception(err) +            _, _, _, _, address = resolved.result()[0] +        except Exception as exc: +            fut.set_exception(exc)          else:              self._sock_connect(fut, sock, address) -        return fut      def _sock_connect(self, fut, sock, address):          fd = sock.fileno() | 
