Commit d6079a4a authored by Denis Bilenko's avatar Denis Bilenko

Merge pull request #559 from gevent/ajdavis_issue_349_r

Fix #349: threaded resolver hangs due to import lock
parents 6fe12a79 b8826b7a
# Copyright (c) 2012 Denis Bilenko. See LICENSE for details. # Copyright (c) 2012 Denis Bilenko. See LICENSE for details.
import _socket import _socket
from gevent.hub import get_hub from gevent.hub import get_hub, text_type
__all__ = ['Resolver'] __all__ = ['Resolver']
# trigger import of encodings.idna to avoid https://github.com/gevent/gevent/issues/349
text_type('foo').encode('idna')
class Resolver(object): class Resolver(object):
expected_errors = Exception expected_errors = Exception
......
import socket
import gevent.socket as gevent_socket
gevent_socket.getaddrinfo(u'gevent.org', None, socket.AF_INET)
# a deadlock is possible if we import a module that runs Gevent's getaddrinfo
# with a unicode hostname, which starts Python's getaddrinfo on a thread, which
# attempts to import encodings.idna but blocks on the import lock. verify
# that Gevent avoids this deadlock.
import getaddrinfo_module
del getaddrinfo_module # fix pyflakes
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment