Commit 913b18bc authored by Jason Madden's avatar Jason Madden

clean up os; fix fork_and_watch to pass the ref argument.

clean up resolver_ares
cleanup thread.
cleanup testrunner
cleanup pool.
clean up event
parent 69a53c64
...@@ -53,3 +53,5 @@ pyflakes: ...@@ -53,3 +53,5 @@ pyflakes:
- F821 - F821
# F401: unused import; same story # F401: unused import; same story
- F401 - F401
# F811: redefined function; same story
- F811
...@@ -13,6 +13,7 @@ ...@@ -13,6 +13,7 @@
- Update c-ares to version 1.11.0 (`release notes <https://raw.githubusercontent.com/c-ares/c-ares/cares-1_11_0/RELEASE-NOTES>`_). - Update c-ares to version 1.11.0 (`release notes <https://raw.githubusercontent.com/c-ares/c-ares/cares-1_11_0/RELEASE-NOTES>`_).
- Remove module ``gevent.coros`` which was replaced by ``gevent.lock`` - Remove module ``gevent.coros`` which was replaced by ``gevent.lock``
and has been deprecated since 1.0b2. and has been deprecated since 1.0b2.
- The ``ref`` parameter to :func:`gevent.os.fork_and_watch` was being ignored.
1.1.0 (Mar 5, 2016) 1.1.0 (Mar 5, 2016)
=================== ===================
......
...@@ -12,7 +12,7 @@ This module implements cooperative SSL socket wrappers. ...@@ -12,7 +12,7 @@ This module implements cooperative SSL socket wrappers.
from __future__ import absolute_import from __future__ import absolute_import
import ssl as __ssl__ import ssl as __ssl__
_ssl = __ssl__._ssl _ssl = __ssl__._ssl # pylint:disable=no-member
import errno import errno
from gevent.socket import socket, timeout_default from gevent.socket import socket, timeout_default
...@@ -30,24 +30,24 @@ __implements__ = [ ...@@ -30,24 +30,24 @@ __implements__ = [
__imports__ = [] __imports__ = []
name = value = None _name = _value = None
for name in dir(__ssl__): for _name in dir(__ssl__):
if name in __implements__: if _name in __implements__:
continue continue
if name.startswith('__'): if _name.startswith('__'):
continue continue
if name == 'socket': if _name == 'socket':
# SSLSocket *must* subclass gevent.socket.socket; see issue 597 # SSLSocket *must* subclass gevent.socket.socket; see issue 597
continue continue
value = getattr(__ssl__, name) _value = getattr(__ssl__, _name)
globals()[name] = value globals()[_name] = _value
__imports__.append(name) __imports__.append(_name)
del name, value del _name, _value
__all__ = __implements__ + __imports__ __all__ = __implements__ + __imports__
orig_SSLContext = __ssl__.SSLContext orig_SSLContext = __ssl__.SSLContext # pylint:disable=no-member
class SSLContext(orig_SSLContext): class SSLContext(orig_SSLContext):
...@@ -103,6 +103,8 @@ class SSLSocket(socket): ...@@ -103,6 +103,8 @@ class SSLSocket(socket):
for Python 3. for Python 3.
""" """
# pylint:disable=too-many-instance-attributes,too-many-public-methods
_gevent_sock_class = _contextawaresock _gevent_sock_class = _contextawaresock
def __init__(self, sock=None, keyfile=None, certfile=None, def __init__(self, sock=None, keyfile=None, certfile=None,
...@@ -113,7 +115,7 @@ class SSLSocket(socket): ...@@ -113,7 +115,7 @@ class SSLSocket(socket):
suppress_ragged_eofs=True, npn_protocols=None, ciphers=None, suppress_ragged_eofs=True, npn_protocols=None, ciphers=None,
server_hostname=None, server_hostname=None,
_context=None): _context=None):
# pylint:disable=too-many-locals,too-many-statements,too-many-branches
if _context: if _context:
self._context = _context self._context = _context
else: else:
...@@ -224,6 +226,7 @@ class SSLSocket(socket): ...@@ -224,6 +226,7 @@ class SSLSocket(socket):
def read(self, len=1024, buffer=None): def read(self, len=1024, buffer=None):
"""Read up to LEN bytes and return them. """Read up to LEN bytes and return them.
Return zero-length string on EOF.""" Return zero-length string on EOF."""
# pylint:disable=too-many-branches
self._checkClosed() self._checkClosed()
if not self._sslobj: if not self._sslobj:
raise ValueError("Read on closed or unwrapped SSL socket.") raise ValueError("Read on closed or unwrapped SSL socket.")
...@@ -584,8 +587,8 @@ def get_server_certificate(addr, ssl_version=PROTOCOL_SSLv23, ca_certs=None): ...@@ -584,8 +587,8 @@ def get_server_certificate(addr, ssl_version=PROTOCOL_SSLv23, ca_certs=None):
If 'ca_certs' is specified, validate the server cert against it. If 'ca_certs' is specified, validate the server cert against it.
If 'ssl_version' is specified, use it in the connection attempt.""" If 'ssl_version' is specified, use it in the connection attempt."""
host, port = addr _, _ = addr
if (ca_certs is not None): if ca_certs is not None:
cert_reqs = CERT_REQUIRED cert_reqs = CERT_REQUIRED
else: else:
cert_reqs = CERT_NONE cert_reqs = CERT_NONE
......
...@@ -79,7 +79,7 @@ class _AbstractLinkable(object): ...@@ -79,7 +79,7 @@ class _AbstractLinkable(object):
if link in self._links: if link in self._links:
try: try:
link(self) link(self)
except: except: # pylint:disable=bare-except
self.hub.handle_error((link, self), *sys.exc_info()) self.hub.handle_error((link, self), *sys.exc_info())
# Mark everything done # Mark everything done
done.update(todo) done.update(todo)
...@@ -114,6 +114,7 @@ class _AbstractLinkable(object): ...@@ -114,6 +114,7 @@ class _AbstractLinkable(object):
self.unlink(switch) self.unlink(switch)
def _wait_return_value(self, waited, wait_success): def _wait_return_value(self, waited, wait_success):
# pylint:disable=unused-argument
return None return None
def _wait(self, timeout=None): def _wait(self, timeout=None):
...@@ -388,6 +389,7 @@ class AsyncResult(_AbstractLinkable): ...@@ -388,6 +389,7 @@ class AsyncResult(_AbstractLinkable):
return self.get(block=False) return self.get(block=False)
def _wait_return_value(self, waited, gotit): def _wait_return_value(self, waited, gotit):
# pylint:disable=unused-argument
# Always return the value. Since this is a one-shot event, # Always return the value. Since this is a one-shot event,
# no race condition should reset it. # no race condition should reset it.
return self.value return self.value
......
...@@ -140,6 +140,8 @@ def tp_write(fd, buf): ...@@ -140,6 +140,8 @@ def tp_write(fd, buf):
if hasattr(os, 'fork'): if hasattr(os, 'fork'):
# pylint:disable=function-redefined,redefined-outer-name
_raw_fork = os.fork _raw_fork = os.fork
def fork_gevent(): def fork_gevent():
...@@ -338,7 +340,7 @@ if hasattr(os, 'fork'): ...@@ -338,7 +340,7 @@ if hasattr(os, 'fork'):
if pid: if pid:
# parent # parent
loop = loop or get_hub().loop loop = loop or get_hub().loop
watcher = loop.child(pid) watcher = loop.child(pid, ref=ref)
_watched_children[pid] = watcher _watched_children[pid] = watcher
watcher.start(_on_child, watcher, callback) watcher.start(_on_child, watcher, callback)
return pid return pid
......
...@@ -113,7 +113,7 @@ class IMapUnordered(Greenlet): ...@@ -113,7 +113,7 @@ class IMapUnordered(Greenlet):
g.rawlink(self._on_result) g.rawlink(self._on_result)
return g return g
def _run(self): def _run(self): # pylint:disable=method-hidden
try: try:
func = self.func func = self.func
for item in self.iterable: for item in self.iterable:
...@@ -241,7 +241,7 @@ class GroupMappingMixin(object): ...@@ -241,7 +241,7 @@ class GroupMappingMixin(object):
def apply_cb(self, func, args=None, kwds=None, callback=None): def apply_cb(self, func, args=None, kwds=None, callback=None):
""" """
:meth:`apply` the given *func(\*args, \*\*kwds)*, and, if a *callback* is given, run it with the :meth:`apply` the given *func(\\*args, \\*\\*kwds)*, and, if a *callback* is given, run it with the
results of *func* (unless an exception was raised.) results of *func* (unless an exception was raised.)
The *callback* may be called synchronously or asynchronously. If called The *callback* may be called synchronously or asynchronously. If called
...@@ -556,23 +556,23 @@ class Group(GroupMappingMixin): ...@@ -556,23 +556,23 @@ class Group(GroupMappingMixin):
""" """
timer = Timeout._start_new_or_dummy(timeout) timer = Timeout._start_new_or_dummy(timeout)
try: try:
try: while self.greenlets:
while self.greenlets: for greenlet in list(self.greenlets):
for greenlet in list(self.greenlets): if greenlet in self.dying:
if greenlet not in self.dying: continue
try: try:
kill = greenlet.kill kill = greenlet.kill
except AttributeError: except AttributeError:
_kill(greenlet, exception) _kill(greenlet, exception)
else: else:
kill(exception, block=False) kill(exception, block=False)
self.dying.add(greenlet) self.dying.add(greenlet)
if not block: if not block:
break break
joinall(self.greenlets) joinall(self.greenlets)
except Timeout as ex: except Timeout as ex:
if ex is not timer: if ex is not timer:
raise raise
finally: finally:
timer.cancel() timer.cancel()
......
...@@ -8,7 +8,7 @@ import sys ...@@ -8,7 +8,7 @@ import sys
from _socket import getservbyname, getaddrinfo, gaierror, error from _socket import getservbyname, getaddrinfo, gaierror, error
from gevent.hub import Waiter, get_hub, string_types, text_type, integer_types, reraise, PY3 from gevent.hub import Waiter, get_hub, string_types, text_type, integer_types, reraise, PY3
from gevent.socket import AF_UNSPEC, AF_INET, AF_INET6, SOCK_STREAM, SOCK_DGRAM, SOCK_RAW, AI_NUMERICHOST, EAI_SERVICE, AI_PASSIVE from gevent.socket import AF_UNSPEC, AF_INET, AF_INET6, SOCK_STREAM, SOCK_DGRAM, SOCK_RAW, AI_NUMERICHOST, EAI_SERVICE, AI_PASSIVE
from gevent.ares import channel, InvalidIP from gevent.ares import channel, InvalidIP # pylint:disable=import-error,no-name-in-module
__all__ = ['Resolver'] __all__ = ['Resolver']
...@@ -101,6 +101,7 @@ class Resolver(object): ...@@ -101,6 +101,7 @@ class Resolver(object):
# "self.ares is not ares" means channel was destroyed (because we were forked) # "self.ares is not ares" means channel was destroyed (because we were forked)
def _lookup_port(self, port, socktype): def _lookup_port(self, port, socktype):
# pylint:disable=too-many-branches
socktypes = [] socktypes = []
if isinstance(port, string_types): if isinstance(port, string_types):
try: try:
...@@ -146,6 +147,7 @@ class Resolver(object): ...@@ -146,6 +147,7 @@ class Resolver(object):
return port, socktypes return port, socktypes
def _getaddrinfo(self, host, port, family=0, socktype=0, proto=0, flags=0): def _getaddrinfo(self, host, port, family=0, socktype=0, proto=0, flags=0):
# pylint:disable=too-many-locals,too-many-branches
if isinstance(host, text_type): if isinstance(host, text_type):
host = host.encode('idna') host = host.encode('idna')
elif not isinstance(host, str) or (flags & AI_NUMERICHOST): elif not isinstance(host, str) or (flags & AI_NUMERICHOST):
...@@ -167,19 +169,19 @@ class Resolver(object): ...@@ -167,19 +169,19 @@ class Resolver(object):
ares = self.ares ares = self.ares
if family == AF_UNSPEC: if family == AF_UNSPEC:
values = Values(self.hub, 2) ares_values = Values(self.hub, 2)
ares.gethostbyname(values, host, AF_INET) ares.gethostbyname(ares_values, host, AF_INET)
ares.gethostbyname(values, host, AF_INET6) ares.gethostbyname(ares_values, host, AF_INET6)
elif family == AF_INET: elif family == AF_INET:
values = Values(self.hub, 1) ares_values = Values(self.hub, 1)
ares.gethostbyname(values, host, AF_INET) ares.gethostbyname(ares_values, host, AF_INET)
elif family == AF_INET6: elif family == AF_INET6:
values = Values(self.hub, 1) ares_values = Values(self.hub, 1)
ares.gethostbyname(values, host, AF_INET6) ares.gethostbyname(ares_values, host, AF_INET6)
else: else:
raise gaierror(5, 'ai_family not supported: %r' % (family, )) raise gaierror(5, 'ai_family not supported: %r' % (family, ))
values = values.get() values = ares_values.get()
if len(values) == 2 and values[0] == values[1]: if len(values) == 2 and values[0] == values[1]:
values.pop() values.pop()
...@@ -281,7 +283,7 @@ class Resolver(object): ...@@ -281,7 +283,7 @@ class Resolver(object):
reraise(*sys.exc_info()) reraise(*sys.exc_info())
elif len(result) != 1: elif len(result) != 1:
raise error('sockaddr resolved to multiple addresses') raise error('sockaddr resolved to multiple addresses')
family, socktype, proto, name, address = result[0] family, _socktype, _proto, _name, address = result[0]
if family == AF_INET: if family == AF_INET:
if len(sockaddr) != 2: if len(sockaddr) != 2:
...@@ -331,7 +333,8 @@ class Values(object): ...@@ -331,7 +333,8 @@ class Values(object):
if self.values: if self.values:
return self.values return self.values
else: else:
raise self.error assert error is not None
raise self.error # pylint:disable=raising-bad-type
def _resolve_special(hostname, family): def _resolve_special(hostname, family):
......
...@@ -19,7 +19,7 @@ __implements__ = ['allocate_lock', ...@@ -19,7 +19,7 @@ __implements__ = ['allocate_lock',
__imports__ = ['error'] __imports__ = ['error']
if sys.version_info[0] <= 2: if sys.version_info[0] <= 2:
import thread as __thread__ import thread as __thread__ # pylint:disable=import-error,useless-suppression
else: else:
import _thread as __thread__ import _thread as __thread__
__target__ = '_thread' __target__ = '_thread'
...@@ -43,8 +43,11 @@ def get_ident(gr=None): ...@@ -43,8 +43,11 @@ def get_ident(gr=None):
return id(gr) return id(gr)
def start_new_thread(function, args=(), kwargs={}): def start_new_thread(function, args=(), kwargs=None):
greenlet = Greenlet.spawn(function, *args, **kwargs) if kwargs is not None:
greenlet = Greenlet.spawn(function, *args, **kwargs)
else:
greenlet = Greenlet.spawn(function, *args)
return get_ident(greenlet) return get_ident(greenlet)
......
...@@ -34,6 +34,7 @@ IGNORE_COVERAGE = [ ...@@ -34,6 +34,7 @@ IGNORE_COVERAGE = [
def run_many(tests, expected=(), failfast=False): def run_many(tests, expected=(), failfast=False):
# pylint:disable=too-many-locals
global NWORKERS global NWORKERS
start = time.time() start = time.time()
total = 0 total = 0
...@@ -71,7 +72,7 @@ def run_many(tests, expected=(), failfast=False): ...@@ -71,7 +72,7 @@ def run_many(tests, expected=(), failfast=False):
while reap() > 0: while reap() > 0:
time.sleep(0.1) time.sleep(0.1)
def spawn(args, kwargs): def spawn(args, kwargs): # pylint:disable=unused-argument
while True: while True:
if reap() < NWORKERS: if reap() < NWORKERS:
r = pool.apply_async(run_one, (cmd, ), options or {}) r = pool.apply_async(run_one, (cmd, ), options or {})
...@@ -117,7 +118,7 @@ def run_many(tests, expected=(), failfast=False): ...@@ -117,7 +118,7 @@ def run_many(tests, expected=(), failfast=False):
def discover(tests=None, ignore=(), coverage=False): def discover(tests=None, ignore=(), coverage=False):
if isinstance(ignore, six.string_types): if isinstance(ignore, six.string_types):
ignore = load_list_from_file(ignore) ignore = set(load_list_from_file(ignore))
ignore = set(ignore or ()) ignore = set(ignore or ())
if coverage: if coverage:
...@@ -194,6 +195,7 @@ def format_seconds(seconds): ...@@ -194,6 +195,7 @@ def format_seconds(seconds):
def report(total, failed, passed, exit=True, took=None, expected=None): def report(total, failed, passed, exit=True, took=None, expected=None):
# pylint:disable=redefined-builtin,too-many-branches
runtimelog = util.runtimelog runtimelog = util.runtimelog
if runtimelog: if runtimelog:
log('\nLongest-running tests:') log('\nLongest-running tests:')
...@@ -253,7 +255,8 @@ def print_list(lst): ...@@ -253,7 +255,8 @@ def print_list(lst):
def main(): def main():
import optparse # FIXME: transition to argparse
import optparse # pylint:disable=deprecated-module
parser = optparse.OptionParser() parser = optparse.OptionParser()
parser.add_option('--ignore') parser.add_option('--ignore')
parser.add_option('--discover', action='store_true') parser.add_option('--discover', action='store_true')
......
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