import _overlapped # Will also be exported.
# This relies on each of the submodules having an __all__ variable.
-from .futures import *
+from .base_events import *
from .events import *
+from .futures import *
from .locks import *
-from .transports import *
+from .proactor_events import *
from .protocols import *
+from .queues import *
+from .selector_events import *
from .streams import *
from .tasks import *
+from .transports import *
if sys.platform == 'win32': # pragma: no cover
from .windows_events import *
from .unix_events import * # pragma: no cover
-__all__ = (futures.__all__ +
+__all__ = (base_events.__all__ +
events.__all__ +
+ futures.__all__ +
locks.__all__ +
- transports.__all__ +
+ proactor_events.__all__ +
protocols.__all__ +
+ queues.__all__ +
+ selector_events.__all__ +
streams.__all__ +
- tasks.__all__)
+ tasks.__all__ +
+ transports.__all__)
proactor is only implemented on Windows with IOCP.
"""
+__all__ = ['BaseProactorEventLoop']
+
import socket
from . import base_events
also includes support for signal handling, see the unix_events sub-module.
"""
+__all__ = ['BaseSelectorEventLoop']
+
import collections
import errno
import socket
"""Stream-related things."""
__all__ = ['StreamReader', 'StreamWriter', 'StreamReaderProtocol',
- 'open_connection', 'start_server',
+ 'open_connection', 'start_server', 'IncompleteReadError',
]
import collections
_DEFAULT_LIMIT = 2**16
+class IncompleteReadError(EOFError):
+ """
+ Incomplete read error. Attributes:
+
+ - partial: read bytes string before the end of stream was reached
+ - expected: total number of expected bytes
+ """
+ def __init__(self, partial, expected):
+ EOFError.__init__(self, "%s bytes read on a total of %s expected bytes"
+ % (len(partial), expected))
+ self.partial = partial
+ self.expected = expected
+
@tasks.coroutine
def open_connection(host=None, port=None, *,
while n > 0:
block = yield from self.read(n)
if not block:
- break
+ partial = b''.join(blocks)
+ raise IncompleteReadError(partial, len(partial) + n)
blocks.append(block)
n -= len(block)
- # TODO: Raise EOFError if we break before n == 0? (That would
- # be a change in specification, but I've always had to add an
- # explicit size check to the caller.)
-
return b''.join(blocks)
self._fileno = pipe.fileno()
mode = os.fstat(self._fileno).st_mode
is_socket = stat.S_ISSOCK(mode)
- is_pipe = stat.S_ISFIFO(mode)
- if not (is_socket or is_pipe):
- raise ValueError("Pipe transport is for pipes/sockets only.")
+ if not (is_socket or
+ stat.S_ISFIFO(mode) or
+ stat.S_ISCHR(mode)):
+ raise ValueError("Pipe transport is only for "
+ "pipes, sockets and character devices")
_set_nonblocking(self._fileno)
self._protocol = protocol
self._buffer = []
import unittest.mock
from test.support import find_unused_port, IPV6_ENABLED
-from asyncio import base_events
+import asyncio
from asyncio import constants
-from asyncio import events
-from asyncio import futures
-from asyncio import protocols
-from asyncio import tasks
from asyncio import test_utils
class BaseEventLoopTests(unittest.TestCase):
def setUp(self):
- self.loop = base_events.BaseEventLoop()
+ self.loop = asyncio.BaseEventLoop()
self.loop._selector = unittest.mock.Mock()
- events.set_event_loop(None)
+ asyncio.set_event_loop(None)
def test_not_implemented(self):
m = unittest.mock.Mock()
self.assertRaises(NotImplementedError, next, iter(gen))
def test__add_callback_handle(self):
- h = events.Handle(lambda: False, ())
+ h = asyncio.Handle(lambda: False, ())
self.loop._add_callback(h)
self.assertFalse(self.loop._scheduled)
self.assertIn(h, self.loop._ready)
def test__add_callback_timer(self):
- h = events.TimerHandle(time.monotonic()+10, lambda: False, ())
+ h = asyncio.TimerHandle(time.monotonic()+10, lambda: False, ())
self.loop._add_callback(h)
self.assertIn(h, self.loop._scheduled)
def test__add_callback_cancelled_handle(self):
- h = events.Handle(lambda: False, ())
+ h = asyncio.Handle(lambda: False, ())
h.cancel()
self.loop._add_callback(h)
h = self.loop.call_soon(cb)
self.assertEqual(h._callback, cb)
- self.assertIsInstance(h, events.Handle)
+ self.assertIsInstance(h, asyncio.Handle)
self.assertIn(h, self.loop._ready)
def test_call_later(self):
pass
h = self.loop.call_later(10.0, cb)
- self.assertIsInstance(h, events.TimerHandle)
+ self.assertIsInstance(h, asyncio.TimerHandle)
self.assertIn(h, self.loop._scheduled)
self.assertNotIn(h, self.loop._ready)
self.assertRaises(
AssertionError, self.loop.run_in_executor,
- None, events.Handle(cb, ()), ('',))
+ None, asyncio.Handle(cb, ()), ('',))
self.assertRaises(
AssertionError, self.loop.run_in_executor,
- None, events.TimerHandle(10, cb, ()))
+ None, asyncio.TimerHandle(10, cb, ()))
def test_run_once_in_executor_cancelled(self):
def cb():
pass
- h = events.Handle(cb, ())
+ h = asyncio.Handle(cb, ())
h.cancel()
f = self.loop.run_in_executor(None, h)
- self.assertIsInstance(f, futures.Future)
+ self.assertIsInstance(f, asyncio.Future)
self.assertTrue(f.done())
self.assertIsNone(f.result())
def test_run_once_in_executor_plain(self):
def cb():
pass
- h = events.Handle(cb, ())
- f = futures.Future(loop=self.loop)
+ h = asyncio.Handle(cb, ())
+ f = asyncio.Future(loop=self.loop)
executor = unittest.mock.Mock()
executor.submit.return_value = f
f.cancel() # Don't complain about abandoned Future.
def test__run_once(self):
- h1 = events.TimerHandle(time.monotonic() + 5.0, lambda: True, ())
- h2 = events.TimerHandle(time.monotonic() + 10.0, lambda: True, ())
+ h1 = asyncio.TimerHandle(time.monotonic() + 5.0, lambda: True, ())
+ h2 = asyncio.TimerHandle(time.monotonic() + 10.0, lambda: True, ())
h1.cancel()
m_logging.DEBUG = logging.DEBUG
self.loop._scheduled.append(
- events.TimerHandle(11.0, lambda: True, ()))
+ asyncio.TimerHandle(11.0, lambda: True, ()))
self.loop._process_events = unittest.mock.Mock()
self.loop._run_once()
self.assertEqual(logging.INFO, m_logging.log.call_args[0][0])
idx = -1
data = [10.0, 10.0, 10.3, 13.0]
- self.loop._scheduled = [events.TimerHandle(11.0, lambda:True, ())]
+ self.loop._scheduled = [asyncio.TimerHandle(11.0, lambda:True, ())]
self.loop._run_once()
self.assertEqual(logging.DEBUG, m_logging.log.call_args[0][0])
processed = True
handle = loop.call_soon(lambda: True)
- h = events.TimerHandle(time.monotonic() - 1, cb, (self.loop,))
+ h = asyncio.TimerHandle(time.monotonic() - 1, cb, (self.loop,))
self.loop._process_events = unittest.mock.Mock()
self.loop._scheduled.append(h)
TypeError, self.loop.run_until_complete, 'blah')
-class MyProto(protocols.Protocol):
+class MyProto(asyncio.Protocol):
done = None
def __init__(self, create_future=False):
self.state = 'INITIAL'
self.nbytes = 0
if create_future:
- self.done = futures.Future()
+ self.done = asyncio.Future()
def connection_made(self, transport):
self.transport = transport
self.done.set_result(None)
-class MyDatagramProto(protocols.DatagramProtocol):
+class MyDatagramProto(asyncio.DatagramProtocol):
done = None
def __init__(self, create_future=False):
self.state = 'INITIAL'
self.nbytes = 0
if create_future:
- self.done = futures.Future()
+ self.done = asyncio.Future()
def connection_made(self, transport):
self.transport = transport
class BaseEventLoopWithSelectorTests(unittest.TestCase):
def setUp(self):
- self.loop = events.new_event_loop()
- events.set_event_loop(None)
+ self.loop = asyncio.new_event_loop()
+ asyncio.set_event_loop(None)
def tearDown(self):
self.loop.close()
@unittest.mock.patch('asyncio.base_events.socket')
def test_create_connection_multiple_errors(self, m_socket):
- class MyProto(protocols.Protocol):
+ class MyProto(asyncio.Protocol):
pass
- @tasks.coroutine
+ @asyncio.coroutine
def getaddrinfo(*args, **kw):
yield from []
return [(2, 1, 6, '', ('107.6.106.82', 80)),
(2, 1, 6, '', ('107.6.106.82', 80))]
def getaddrinfo_task(*args, **kwds):
- return tasks.Task(getaddrinfo(*args, **kwds), loop=self.loop)
+ return asyncio.Task(getaddrinfo(*args, **kwds), loop=self.loop)
idx = -1
errors = ['err1', 'err2']
self.assertRaises(ValueError, self.loop.run_until_complete, coro)
def test_create_connection_no_getaddrinfo(self):
- @tasks.coroutine
+ @asyncio.coroutine
def getaddrinfo(*args, **kw):
yield from []
def getaddrinfo_task(*args, **kwds):
- return tasks.Task(getaddrinfo(*args, **kwds), loop=self.loop)
+ return asyncio.Task(getaddrinfo(*args, **kwds), loop=self.loop)
self.loop.getaddrinfo = getaddrinfo_task
coro = self.loop.create_connection(MyProto, 'example.com', 80)
OSError, self.loop.run_until_complete, coro)
def test_create_connection_connect_err(self):
- @tasks.coroutine
+ @asyncio.coroutine
def getaddrinfo(*args, **kw):
yield from []
return [(2, 1, 6, '', ('107.6.106.82', 80))]
def getaddrinfo_task(*args, **kwds):
- return tasks.Task(getaddrinfo(*args, **kwds), loop=self.loop)
+ return asyncio.Task(getaddrinfo(*args, **kwds), loop=self.loop)
self.loop.getaddrinfo = getaddrinfo_task
self.loop.sock_connect = unittest.mock.Mock()
OSError, self.loop.run_until_complete, coro)
def test_create_connection_multiple(self):
- @tasks.coroutine
+ @asyncio.coroutine
def getaddrinfo(*args, **kw):
return [(2, 1, 6, '', ('0.0.0.1', 80)),
(2, 1, 6, '', ('0.0.0.2', 80))]
def getaddrinfo_task(*args, **kwds):
- return tasks.Task(getaddrinfo(*args, **kwds), loop=self.loop)
+ return asyncio.Task(getaddrinfo(*args, **kwds), loop=self.loop)
self.loop.getaddrinfo = getaddrinfo_task
self.loop.sock_connect = unittest.mock.Mock()
m_socket.socket.return_value.bind = bind
- @tasks.coroutine
+ @asyncio.coroutine
def getaddrinfo(*args, **kw):
return [(2, 1, 6, '', ('0.0.0.1', 80)),
(2, 1, 6, '', ('0.0.0.2', 80))]
def getaddrinfo_task(*args, **kwds):
- return tasks.Task(getaddrinfo(*args, **kwds), loop=self.loop)
+ return asyncio.Task(getaddrinfo(*args, **kwds), loop=self.loop)
self.loop.getaddrinfo = getaddrinfo_task
self.loop.sock_connect = unittest.mock.Mock()
self.assertTrue(m_socket.socket.return_value.close.called)
def test_create_connection_no_local_addr(self):
- @tasks.coroutine
+ @asyncio.coroutine
def getaddrinfo(host, *args, **kw):
if host == 'example.com':
return [(2, 1, 6, '', ('107.6.106.82', 80)),
return []
def getaddrinfo_task(*args, **kwds):
- return tasks.Task(getaddrinfo(*args, **kwds), loop=self.loop)
+ return asyncio.Task(getaddrinfo(*args, **kwds), loop=self.loop)
self.loop.getaddrinfo = getaddrinfo_task
coro = self.loop.create_connection(
self.loop.getaddrinfo = unittest.mock.Mock()
def mock_getaddrinfo(*args, **kwds):
- f = futures.Future(loop=self.loop)
+ f = asyncio.Future(loop=self.loop)
f.set_result([(socket.AF_INET, socket.SOCK_STREAM,
socket.SOL_TCP, '', ('1.2.3.4', 80))])
return f
# if host is empty string use None instead
host = object()
- @tasks.coroutine
+ @asyncio.coroutine
def getaddrinfo(*args, **kw):
nonlocal host
host = args[0]
yield from []
def getaddrinfo_task(*args, **kwds):
- return tasks.Task(getaddrinfo(*args, **kwds), loop=self.loop)
+ return asyncio.Task(getaddrinfo(*args, **kwds), loop=self.loop)
self.loop.getaddrinfo = getaddrinfo_task
fut = self.loop.create_server(MyProto, '', 0)
self.loop.sock_connect.side_effect = OSError
coro = self.loop.create_datagram_endpoint(
- protocols.DatagramProtocol, remote_addr=('127.0.0.1', 0))
+ asyncio.DatagramProtocol, remote_addr=('127.0.0.1', 0))
self.assertRaises(
OSError, self.loop.run_until_complete, coro)
m_socket.socket.side_effect = OSError
coro = self.loop.create_datagram_endpoint(
- protocols.DatagramProtocol, family=socket.AF_INET)
+ asyncio.DatagramProtocol, family=socket.AF_INET)
self.assertRaises(
OSError, self.loop.run_until_complete, coro)
coro = self.loop.create_datagram_endpoint(
- protocols.DatagramProtocol, local_addr=('127.0.0.1', 0))
+ asyncio.DatagramProtocol, local_addr=('127.0.0.1', 0))
self.assertRaises(
OSError, self.loop.run_until_complete, coro)
@unittest.skipUnless(IPV6_ENABLED, 'IPv6 not supported or enabled')
def test_create_datagram_endpoint_no_matching_family(self):
coro = self.loop.create_datagram_endpoint(
- protocols.DatagramProtocol,
+ asyncio.DatagramProtocol,
remote_addr=('127.0.0.1', 0), local_addr=('::1', 0))
self.assertRaises(
ValueError, self.loop.run_until_complete, coro)
m_socket.socket.return_value.setblocking.side_effect = OSError
coro = self.loop.create_datagram_endpoint(
- protocols.DatagramProtocol, family=socket.AF_INET)
+ asyncio.DatagramProtocol, family=socket.AF_INET)
self.assertRaises(
OSError, self.loop.run_until_complete, coro)
self.assertTrue(
def test_create_datagram_endpoint_noaddr_nofamily(self):
coro = self.loop.create_datagram_endpoint(
- protocols.DatagramProtocol)
+ asyncio.DatagramProtocol)
self.assertRaises(ValueError, self.loop.run_until_complete, coro)
@unittest.mock.patch('asyncio.base_events.socket')
from test import support # find_unused_port, IPV6_ENABLED, TEST_HOME_DIR
-from asyncio import futures
+import asyncio
from asyncio import events
-from asyncio import transports
-from asyncio import protocols
-from asyncio import selector_events
-from asyncio import tasks
from asyncio import test_utils
-from asyncio import locks
def data_file(filename):
SIGNING_CA = data_file('pycacert.pem')
-class MyProto(protocols.Protocol):
+class MyProto(asyncio.Protocol):
done = None
def __init__(self, loop=None):
self.state = 'INITIAL'
self.nbytes = 0
if loop is not None:
- self.done = futures.Future(loop=loop)
+ self.done = asyncio.Future(loop=loop)
def connection_made(self, transport):
self.transport = transport
self.done.set_result(None)
-class MyDatagramProto(protocols.DatagramProtocol):
+class MyDatagramProto(asyncio.DatagramProtocol):
done = None
def __init__(self, loop=None):
self.state = 'INITIAL'
self.nbytes = 0
if loop is not None:
- self.done = futures.Future(loop=loop)
+ self.done = asyncio.Future(loop=loop)
def connection_made(self, transport):
self.transport = transport
self.done.set_result(None)
-class MyReadPipeProto(protocols.Protocol):
+class MyReadPipeProto(asyncio.Protocol):
done = None
def __init__(self, loop=None):
self.nbytes = 0
self.transport = None
if loop is not None:
- self.done = futures.Future(loop=loop)
+ self.done = asyncio.Future(loop=loop)
def connection_made(self, transport):
self.transport = transport
self.done.set_result(None)
-class MyWritePipeProto(protocols.BaseProtocol):
+class MyWritePipeProto(asyncio.BaseProtocol):
done = None
def __init__(self, loop=None):
self.state = 'INITIAL'
self.transport = None
if loop is not None:
- self.done = futures.Future(loop=loop)
+ self.done = asyncio.Future(loop=loop)
def connection_made(self, transport):
self.transport = transport
self.done.set_result(None)
-class MySubprocessProtocol(protocols.SubprocessProtocol):
+class MySubprocessProtocol(asyncio.SubprocessProtocol):
def __init__(self, loop):
self.state = 'INITIAL'
self.transport = None
- self.connected = futures.Future(loop=loop)
- self.completed = futures.Future(loop=loop)
- self.disconnects = {fd: futures.Future(loop=loop) for fd in range(3)}
+ self.connected = asyncio.Future(loop=loop)
+ self.completed = asyncio.Future(loop=loop)
+ self.disconnects = {fd: asyncio.Future(loop=loop) for fd in range(3)}
self.data = {1: b'', 2: b''}
self.returncode = None
- self.got_data = {1: locks.Event(loop=loop),
- 2: locks.Event(loop=loop)}
+ self.got_data = {1: asyncio.Event(loop=loop),
+ 2: asyncio.Event(loop=loop)}
def connection_made(self, transport):
self.transport = transport
def setUp(self):
super().setUp()
self.loop = self.create_event_loop()
- events.set_event_loop(None)
+ asyncio.set_event_loop(None)
def tearDown(self):
# just in case if we have transport close callbacks
super().tearDown()
def test_run_until_complete_nesting(self):
- @tasks.coroutine
+ @asyncio.coroutine
def coro1():
yield
- @tasks.coroutine
+ @asyncio.coroutine
def coro2():
self.assertTrue(self.loop.is_running())
self.loop.run_until_complete(coro1())
def test_run_until_complete(self):
t0 = self.loop.time()
- self.loop.run_until_complete(tasks.sleep(0.1, loop=self.loop))
+ self.loop.run_until_complete(asyncio.sleep(0.1, loop=self.loop))
t1 = self.loop.time()
self.assertTrue(0.08 <= t1-t0 <= 0.8, t1-t0)
def test_run_until_complete_stopped(self):
- @tasks.coroutine
+ @asyncio.coroutine
def cb():
self.loop.stop()
- yield from tasks.sleep(0.1, loop=self.loop)
+ yield from asyncio.sleep(0.1, loop=self.loop)
task = cb()
self.assertRaises(RuntimeError,
self.loop.run_until_complete, task)
f = self.loop.create_connection(
lambda: MyProto(loop=self.loop), *httpd.address)
tr, pr = self.loop.run_until_complete(f)
- self.assertIsInstance(tr, transports.Transport)
- self.assertIsInstance(pr, protocols.Protocol)
+ self.assertIsInstance(tr, asyncio.Transport)
+ self.assertIsInstance(pr, asyncio.Protocol)
self.loop.run_until_complete(pr.done)
self.assertGreater(pr.nbytes, 0)
tr.close()
f = self.loop.create_connection(
lambda: MyProto(loop=self.loop), sock=sock)
tr, pr = self.loop.run_until_complete(f)
- self.assertIsInstance(tr, transports.Transport)
- self.assertIsInstance(pr, protocols.Protocol)
+ self.assertIsInstance(tr, asyncio.Transport)
+ self.assertIsInstance(pr, asyncio.Protocol)
self.loop.run_until_complete(pr.done)
self.assertGreater(pr.nbytes, 0)
tr.close()
lambda: MyProto(loop=self.loop), *httpd.address,
ssl=test_utils.dummy_ssl_context())
tr, pr = self.loop.run_until_complete(f)
- self.assertIsInstance(tr, transports.Transport)
- self.assertIsInstance(pr, protocols.Protocol)
+ self.assertIsInstance(tr, asyncio.Transport)
+ self.assertIsInstance(pr, asyncio.Protocol)
self.assertTrue('ssl' in tr.__class__.__name__.lower())
self.assertIsNotNone(tr.get_extra_info('sockname'))
self.loop.run_until_complete(pr.done)
server.close()
def test_create_server_sock(self):
- proto = futures.Future(loop=self.loop)
+ proto = asyncio.Future(loop=self.loop)
class TestMyProto(MyProto):
def connection_made(self, transport):
@unittest.skipUnless(support.IPV6_ENABLED, 'IPv6 not supported or enabled')
def test_create_server_dual_stack(self):
- f_proto = futures.Future(loop=self.loop)
+ f_proto = asyncio.Future(loop=self.loop)
class TestMyProto(MyProto):
def connection_made(self, transport):
proto.transport.close()
client.close()
- f_proto = futures.Future(loop=self.loop)
+ f_proto = asyncio.Future(loop=self.loop)
client = socket.socket(socket.AF_INET6)
client.connect(('::1', port))
client.send(b'xxx')
def test_internal_fds(self):
loop = self.create_event_loop()
- if not isinstance(loop, selector_events.BaseSelectorEventLoop):
+ if not isinstance(loop, asyncio.BaseSelectorEventLoop):
self.skipTest('loop is not a BaseSelectorEventLoop')
self.assertEqual(1, loop._internal_fds)
rpipe, wpipe = os.pipe()
pipeobj = io.open(rpipe, 'rb', 1024)
- @tasks.coroutine
+ @asyncio.coroutine
def connect():
t, p = yield from self.loop.connect_read_pipe(factory, pipeobj)
self.assertIs(p, proto)
@unittest.skipUnless(sys.platform != 'win32',
"Don't support pipes for Windows")
- # kqueue doesn't support character devices (PTY) on Mac OS X older
- # than 10.9 (Maverick)
- @support.requires_mac_ver(10, 9)
def test_read_pty_output(self):
proto = None
master, slave = os.openpty()
master_read_obj = io.open(master, 'rb', 0)
- @tasks.coroutine
+ @asyncio.coroutine
def connect():
t, p = yield from self.loop.connect_read_pipe(factory,
master_read_obj)
rpipe, wpipe = os.pipe()
pipeobj = io.open(wpipe, 'wb', 1024)
- @tasks.coroutine
+ @asyncio.coroutine
def connect():
nonlocal transport
t, p = yield from self.loop.connect_write_pipe(factory, pipeobj)
rsock, wsock = test_utils.socketpair()
pipeobj = io.open(wsock.detach(), 'wb', 1024)
- @tasks.coroutine
+ @asyncio.coroutine
def connect():
nonlocal transport
t, p = yield from self.loop.connect_write_pipe(factory,
self.loop.run_until_complete(proto.done)
self.assertEqual('CLOSED', proto.state)
+ @unittest.skipUnless(sys.platform != 'win32',
+ "Don't support pipes for Windows")
+ def test_write_pty(self):
+ proto = None
+ transport = None
+
+ def factory():
+ nonlocal proto
+ proto = MyWritePipeProto(loop=self.loop)
+ return proto
+
+ master, slave = os.openpty()
+ slave_write_obj = io.open(slave, 'wb', 0)
+
+ @asyncio.coroutine
+ def connect():
+ nonlocal transport
+ t, p = yield from self.loop.connect_write_pipe(factory,
+ slave_write_obj)
+ self.assertIs(p, proto)
+ self.assertIs(t, proto.transport)
+ self.assertEqual('CONNECTED', proto.state)
+ transport = t
+
+ self.loop.run_until_complete(connect())
+
+ transport.write(b'1')
+ test_utils.run_briefly(self.loop)
+ data = os.read(master, 1024)
+ self.assertEqual(b'1', data)
+
+ transport.write(b'2345')
+ test_utils.run_briefly(self.loop)
+ data = os.read(master, 1024)
+ self.assertEqual(b'2345', data)
+ self.assertEqual('CONNECTED', proto.state)
+
+ os.close(master)
+
+ # extra info is available
+ self.assertIsNotNone(proto.transport.get_extra_info('pipe'))
+
+ # close connection
+ proto.transport.close()
+ self.loop.run_until_complete(proto.done)
+ self.assertEqual('CLOSED', proto.state)
+
def test_prompt_cancellation(self):
r, w = test_utils.socketpair()
r.setblocking(False)
if ov is not None:
self.assertTrue(ov.pending)
- @tasks.coroutine
+ @asyncio.coroutine
def main():
try:
self.loop.call_soon(f.cancel)
yield from f
- except futures.CancelledError:
+ except asyncio.CancelledError:
res = 'cancelled'
else:
res = None
return res
start = time.monotonic()
- t = tasks.Task(main(), loop=self.loop)
+ t = asyncio.Task(main(), loop=self.loop)
self.loop.run_forever()
elapsed = time.monotonic() - start
self.assertLess(elapsed, 0.1)
self.assertEqual(t.result(), 'cancelled')
- self.assertRaises(futures.CancelledError, f.result)
+ self.assertRaises(asyncio.CancelledError, f.result)
if ov is not None:
self.assertFalse(ov.pending)
self.loop._stop_serving(r)
self.loop._run_once = _run_once
calls = []
- @tasks.coroutine
+ @asyncio.coroutine
def wait():
loop = self.loop
calls.append(loop._run_once_counter)
- yield from tasks.sleep(loop.granularity * 10, loop=loop)
+ yield from asyncio.sleep(loop.granularity * 10, loop=loop)
calls.append(loop._run_once_counter)
- yield from tasks.sleep(loop.granularity / 10, loop=loop)
+ yield from asyncio.sleep(loop.granularity / 10, loop=loop)
calls.append(loop._run_once_counter)
self.loop.run_until_complete(wait())
prog = os.path.join(os.path.dirname(__file__), 'echo.py')
- @tasks.coroutine
+ @asyncio.coroutine
def connect():
nonlocal proto, transp
transp, proto = yield from self.loop.subprocess_exec(
prog = os.path.join(os.path.dirname(__file__), 'echo.py')
- @tasks.coroutine
+ @asyncio.coroutine
def connect():
nonlocal proto, transp
transp, proto = yield from self.loop.subprocess_exec(
proto = None
transp = None
- @tasks.coroutine
+ @asyncio.coroutine
def connect():
nonlocal proto, transp
transp, proto = yield from self.loop.subprocess_shell(
def test_subprocess_exitcode(self):
proto = None
- @tasks.coroutine
+ @asyncio.coroutine
def connect():
nonlocal proto
transp, proto = yield from self.loop.subprocess_shell(
proto = None
transp = None
- @tasks.coroutine
+ @asyncio.coroutine
def connect():
nonlocal proto, transp
transp, proto = yield from self.loop.subprocess_shell(
prog = os.path.join(os.path.dirname(__file__), 'echo.py')
- @tasks.coroutine
+ @asyncio.coroutine
def connect():
nonlocal proto, transp
transp, proto = yield from self.loop.subprocess_exec(
prog = os.path.join(os.path.dirname(__file__), 'echo.py')
- @tasks.coroutine
+ @asyncio.coroutine
def connect():
nonlocal proto, transp
transp, proto = yield from self.loop.subprocess_exec(
prog = os.path.join(os.path.dirname(__file__), 'echo.py')
- @tasks.coroutine
+ @asyncio.coroutine
def connect():
nonlocal proto, transp
transp, proto = yield from self.loop.subprocess_exec(
prog = os.path.join(os.path.dirname(__file__), 'echo2.py')
- @tasks.coroutine
+ @asyncio.coroutine
def connect():
nonlocal proto, transp
transp, proto = yield from self.loop.subprocess_exec(
prog = os.path.join(os.path.dirname(__file__), 'echo2.py')
- @tasks.coroutine
+ @asyncio.coroutine
def connect():
nonlocal proto, transp
transp, proto = yield from self.loop.subprocess_exec(
prog = os.path.join(os.path.dirname(__file__), 'echo3.py')
- @tasks.coroutine
+ @asyncio.coroutine
def connect():
nonlocal proto, transp
transp, proto = yield from self.loop.subprocess_exec(
proto = None
transp = None
- @tasks.coroutine
+ @asyncio.coroutine
def connect():
nonlocal proto
# start the new process in a new session
if sys.platform == 'win32':
- from asyncio import windows_events
class SelectEventLoopTests(EventLoopTestsMixin, unittest.TestCase):
def create_event_loop(self):
- return windows_events.SelectorEventLoop()
+ return asyncio.SelectorEventLoop()
class ProactorEventLoopTests(EventLoopTestsMixin,
SubprocessTestsMixin,
unittest.TestCase):
def create_event_loop(self):
- return windows_events.ProactorEventLoop()
+ return asyncio.ProactorEventLoop()
def test_create_ssl_connection(self):
raise unittest.SkipTest("IocpEventLoop incompatible with SSL")
"IocpEventLoop does not have create_datagram_endpoint()")
else:
from asyncio import selectors
- from asyncio import unix_events
class UnixEventLoopTestsMixin(EventLoopTestsMixin):
def setUp(self):
super().setUp()
- watcher = unix_events.SafeChildWatcher()
+ watcher = asyncio.SafeChildWatcher()
watcher.attach_loop(self.loop)
- events.set_child_watcher(watcher)
+ asyncio.set_child_watcher(watcher)
def tearDown(self):
- events.set_child_watcher(None)
+ asyncio.set_child_watcher(None)
super().tearDown()
if hasattr(selectors, 'KqueueSelector'):
unittest.TestCase):
def create_event_loop(self):
- return unix_events.SelectorEventLoop(
+ return asyncio.SelectorEventLoop(
selectors.KqueueSelector())
+ # kqueue doesn't support character devices (PTY) on Mac OS X older
+ # than 10.9 (Maverick)
+ @support.requires_mac_ver(10, 9)
+ def test_read_pty_output(self):
+ super().test_read_pty_output()
+
+ # kqueue doesn't support character devices (PTY) on Mac OS X older
+ # than 10.9 (Maverick)
+ @support.requires_mac_ver(10, 9)
+ def test_write_pty(self):
+ super().test_write_pty()
+
if hasattr(selectors, 'EpollSelector'):
class EPollEventLoopTests(UnixEventLoopTestsMixin,
SubprocessTestsMixin,
unittest.TestCase):
def create_event_loop(self):
- return unix_events.SelectorEventLoop(selectors.EpollSelector())
+ return asyncio.SelectorEventLoop(selectors.EpollSelector())
if hasattr(selectors, 'PollSelector'):
class PollEventLoopTests(UnixEventLoopTestsMixin,
unittest.TestCase):
def create_event_loop(self):
- return unix_events.SelectorEventLoop(selectors.PollSelector())
+ return asyncio.SelectorEventLoop(selectors.PollSelector())
# Should always exist.
class SelectEventLoopTests(UnixEventLoopTestsMixin,
unittest.TestCase):
def create_event_loop(self):
- return unix_events.SelectorEventLoop(selectors.SelectSelector())
+ return asyncio.SelectorEventLoop(selectors.SelectSelector())
class HandleTests(unittest.TestCase):
return args
args = ()
- h = events.Handle(callback, args)
+ h = asyncio.Handle(callback, args)
self.assertIs(h._callback, callback)
self.assertIs(h._args, args)
self.assertFalse(h._cancelled)
def test_make_handle(self):
def callback(*args):
return args
- h1 = events.Handle(callback, ())
+ h1 = asyncio.Handle(callback, ())
self.assertRaises(
- AssertionError, events.make_handle, h1, ())
+ AssertionError, asyncio.events.make_handle, h1, ())
@unittest.mock.patch('asyncio.events.logger')
def test_callback_with_exception(self, log):
def callback():
raise ValueError()
- h = events.Handle(callback, ())
+ h = asyncio.Handle(callback, ())
h._run()
self.assertTrue(log.exception.called)
def test_hash(self):
when = time.monotonic()
- h = events.TimerHandle(when, lambda: False, ())
+ h = asyncio.TimerHandle(when, lambda: False, ())
self.assertEqual(hash(h), hash(when))
def test_timer(self):
args = ()
when = time.monotonic()
- h = events.TimerHandle(when, callback, args)
+ h = asyncio.TimerHandle(when, callback, args)
self.assertIs(h._callback, callback)
self.assertIs(h._args, args)
self.assertFalse(h._cancelled)
self.assertTrue(r.endswith('())<cancelled>'), r)
self.assertRaises(AssertionError,
- events.TimerHandle, None, callback, args)
+ asyncio.TimerHandle, None, callback, args)
def test_timer_comparison(self):
def callback(*args):
when = time.monotonic()
- h1 = events.TimerHandle(when, callback, ())
- h2 = events.TimerHandle(when, callback, ())
+ h1 = asyncio.TimerHandle(when, callback, ())
+ h2 = asyncio.TimerHandle(when, callback, ())
# TODO: Use assertLess etc.
self.assertFalse(h1 < h2)
self.assertFalse(h2 < h1)
h2.cancel()
self.assertFalse(h1 == h2)
- h1 = events.TimerHandle(when, callback, ())
- h2 = events.TimerHandle(when + 10.0, callback, ())
+ h1 = asyncio.TimerHandle(when, callback, ())
+ h2 = asyncio.TimerHandle(when + 10.0, callback, ())
self.assertTrue(h1 < h2)
self.assertFalse(h2 < h1)
self.assertTrue(h1 <= h2)
self.assertFalse(h1 == h2)
self.assertTrue(h1 != h2)
- h3 = events.Handle(callback, ())
+ h3 = asyncio.Handle(callback, ())
self.assertIs(NotImplemented, h1.__eq__(h3))
self.assertIs(NotImplemented, h1.__ne__(h3))
def test_not_implemented(self):
f = unittest.mock.Mock()
- loop = events.AbstractEventLoop()
+ loop = asyncio.AbstractEventLoop()
self.assertRaises(
NotImplementedError, loop.run_forever)
self.assertRaises(
def test_empty(self):
f = unittest.mock.Mock()
- p = protocols.Protocol()
+ p = asyncio.Protocol()
self.assertIsNone(p.connection_made(f))
self.assertIsNone(p.connection_lost(f))
self.assertIsNone(p.data_received(f))
self.assertIsNone(p.eof_received())
- dp = protocols.DatagramProtocol()
+ dp = asyncio.DatagramProtocol()
self.assertIsNone(dp.connection_made(f))
self.assertIsNone(dp.connection_lost(f))
self.assertIsNone(dp.error_received(f))
self.assertIsNone(dp.datagram_received(f, f))
- sp = protocols.SubprocessProtocol()
+ sp = asyncio.SubprocessProtocol()
self.assertIsNone(sp.connection_made(f))
self.assertIsNone(sp.connection_lost(f))
self.assertIsNone(sp.pipe_data_received(1, f))
class PolicyTests(unittest.TestCase):
- def create_policy(self):
- if sys.platform == "win32":
- from asyncio import windows_events
- return windows_events.DefaultEventLoopPolicy()
- else:
- from asyncio import unix_events
- return unix_events.DefaultEventLoopPolicy()
-
def test_event_loop_policy(self):
- policy = events.AbstractEventLoopPolicy()
+ policy = asyncio.AbstractEventLoopPolicy()
self.assertRaises(NotImplementedError, policy.get_event_loop)
self.assertRaises(NotImplementedError, policy.set_event_loop, object())
self.assertRaises(NotImplementedError, policy.new_event_loop)
object())
def test_get_event_loop(self):
- policy = self.create_policy()
+ policy = asyncio.DefaultEventLoopPolicy()
self.assertIsNone(policy._local._loop)
loop = policy.get_event_loop()
- self.assertIsInstance(loop, events.AbstractEventLoop)
+ self.assertIsInstance(loop, asyncio.AbstractEventLoop)
self.assertIs(policy._local._loop, loop)
self.assertIs(loop, policy.get_event_loop())
loop.close()
def test_get_event_loop_calls_set_event_loop(self):
- policy = self.create_policy()
+ policy = asyncio.DefaultEventLoopPolicy()
with unittest.mock.patch.object(
policy, "set_event_loop",
loop.close()
def test_get_event_loop_after_set_none(self):
- policy = self.create_policy()
+ policy = asyncio.DefaultEventLoopPolicy()
policy.set_event_loop(None)
self.assertRaises(AssertionError, policy.get_event_loop)
def test_get_event_loop_thread(self, m_current_thread):
def f():
- policy = self.create_policy()
+ policy = asyncio.DefaultEventLoopPolicy()
self.assertRaises(AssertionError, policy.get_event_loop)
th = threading.Thread(target=f)
th.join()
def test_new_event_loop(self):
- policy = self.create_policy()
+ policy = asyncio.DefaultEventLoopPolicy()
loop = policy.new_event_loop()
- self.assertIsInstance(loop, events.AbstractEventLoop)
+ self.assertIsInstance(loop, asyncio.AbstractEventLoop)
loop.close()
def test_set_event_loop(self):
- policy = self.create_policy()
+ policy = asyncio.DefaultEventLoopPolicy()
old_loop = policy.get_event_loop()
self.assertRaises(AssertionError, policy.set_event_loop, object())
old_loop.close()
def test_get_event_loop_policy(self):
- policy = events.get_event_loop_policy()
- self.assertIsInstance(policy, events.AbstractEventLoopPolicy)
- self.assertIs(policy, events.get_event_loop_policy())
+ policy = asyncio.get_event_loop_policy()
+ self.assertIsInstance(policy, asyncio.AbstractEventLoopPolicy)
+ self.assertIs(policy, asyncio.get_event_loop_policy())
def test_set_event_loop_policy(self):
self.assertRaises(
- AssertionError, events.set_event_loop_policy, object())
+ AssertionError, asyncio.set_event_loop_policy, object())
- old_policy = events.get_event_loop_policy()
+ old_policy = asyncio.get_event_loop_policy()
- policy = self.create_policy()
- events.set_event_loop_policy(policy)
- self.assertIs(policy, events.get_event_loop_policy())
+ policy = asyncio.DefaultEventLoopPolicy()
+ asyncio.set_event_loop_policy(policy)
+ self.assertIs(policy, asyncio.get_event_loop_policy())
self.assertIsNot(policy, old_policy)
import unittest
import unittest.mock
-from asyncio import events
-from asyncio import futures
+import asyncio
from asyncio import test_utils
def setUp(self):
self.loop = test_utils.TestLoop()
- events.set_event_loop(None)
+ asyncio.set_event_loop(None)
def tearDown(self):
self.loop.close()
def test_initial_state(self):
- f = futures.Future(loop=self.loop)
+ f = asyncio.Future(loop=self.loop)
self.assertFalse(f.cancelled())
self.assertFalse(f.done())
f.cancel()
def test_init_constructor_default_loop(self):
try:
- events.set_event_loop(self.loop)
- f = futures.Future()
+ asyncio.set_event_loop(self.loop)
+ f = asyncio.Future()
self.assertIs(f._loop, self.loop)
finally:
- events.set_event_loop(None)
+ asyncio.set_event_loop(None)
def test_constructor_positional(self):
# Make sure Future does't accept a positional argument
- self.assertRaises(TypeError, futures.Future, 42)
+ self.assertRaises(TypeError, asyncio.Future, 42)
def test_cancel(self):
- f = futures.Future(loop=self.loop)
+ f = asyncio.Future(loop=self.loop)
self.assertTrue(f.cancel())
self.assertTrue(f.cancelled())
self.assertTrue(f.done())
- self.assertRaises(futures.CancelledError, f.result)
- self.assertRaises(futures.CancelledError, f.exception)
- self.assertRaises(futures.InvalidStateError, f.set_result, None)
- self.assertRaises(futures.InvalidStateError, f.set_exception, None)
+ self.assertRaises(asyncio.CancelledError, f.result)
+ self.assertRaises(asyncio.CancelledError, f.exception)
+ self.assertRaises(asyncio.InvalidStateError, f.set_result, None)
+ self.assertRaises(asyncio.InvalidStateError, f.set_exception, None)
self.assertFalse(f.cancel())
def test_result(self):
- f = futures.Future(loop=self.loop)
- self.assertRaises(futures.InvalidStateError, f.result)
+ f = asyncio.Future(loop=self.loop)
+ self.assertRaises(asyncio.InvalidStateError, f.result)
f.set_result(42)
self.assertFalse(f.cancelled())
self.assertTrue(f.done())
self.assertEqual(f.result(), 42)
self.assertEqual(f.exception(), None)
- self.assertRaises(futures.InvalidStateError, f.set_result, None)
- self.assertRaises(futures.InvalidStateError, f.set_exception, None)
+ self.assertRaises(asyncio.InvalidStateError, f.set_result, None)
+ self.assertRaises(asyncio.InvalidStateError, f.set_exception, None)
self.assertFalse(f.cancel())
def test_exception(self):
exc = RuntimeError()
- f = futures.Future(loop=self.loop)
- self.assertRaises(futures.InvalidStateError, f.exception)
+ f = asyncio.Future(loop=self.loop)
+ self.assertRaises(asyncio.InvalidStateError, f.exception)
f.set_exception(exc)
self.assertFalse(f.cancelled())
self.assertTrue(f.done())
self.assertRaises(RuntimeError, f.result)
self.assertEqual(f.exception(), exc)
- self.assertRaises(futures.InvalidStateError, f.set_result, None)
- self.assertRaises(futures.InvalidStateError, f.set_exception, None)
+ self.assertRaises(asyncio.InvalidStateError, f.set_result, None)
+ self.assertRaises(asyncio.InvalidStateError, f.set_exception, None)
self.assertFalse(f.cancel())
def test_yield_from_twice(self):
- f = futures.Future(loop=self.loop)
+ f = asyncio.Future(loop=self.loop)
def fixture():
yield 'A'
self.assertEqual(next(g), ('C', 42)) # yield 'C', y.
def test_repr(self):
- f_pending = futures.Future(loop=self.loop)
+ f_pending = asyncio.Future(loop=self.loop)
self.assertEqual(repr(f_pending), 'Future<PENDING>')
f_pending.cancel()
- f_cancelled = futures.Future(loop=self.loop)
+ f_cancelled = asyncio.Future(loop=self.loop)
f_cancelled.cancel()
self.assertEqual(repr(f_cancelled), 'Future<CANCELLED>')
- f_result = futures.Future(loop=self.loop)
+ f_result = asyncio.Future(loop=self.loop)
f_result.set_result(4)
self.assertEqual(repr(f_result), 'Future<result=4>')
self.assertEqual(f_result.result(), 4)
exc = RuntimeError()
- f_exception = futures.Future(loop=self.loop)
+ f_exception = asyncio.Future(loop=self.loop)
f_exception.set_exception(exc)
self.assertEqual(repr(f_exception), 'Future<exception=RuntimeError()>')
self.assertIs(f_exception.exception(), exc)
- f_few_callbacks = futures.Future(loop=self.loop)
+ f_few_callbacks = asyncio.Future(loop=self.loop)
f_few_callbacks.add_done_callback(_fakefunc)
self.assertIn('Future<PENDING, [<function _fakefunc',
repr(f_few_callbacks))
f_few_callbacks.cancel()
- f_many_callbacks = futures.Future(loop=self.loop)
+ f_many_callbacks = asyncio.Future(loop=self.loop)
for i in range(20):
f_many_callbacks.add_done_callback(_fakefunc)
r = repr(f_many_callbacks)
def test_copy_state(self):
# Test the internal _copy_state method since it's being directly
# invoked in other modules.
- f = futures.Future(loop=self.loop)
+ f = asyncio.Future(loop=self.loop)
f.set_result(10)
- newf = futures.Future(loop=self.loop)
+ newf = asyncio.Future(loop=self.loop)
newf._copy_state(f)
self.assertTrue(newf.done())
self.assertEqual(newf.result(), 10)
- f_exception = futures.Future(loop=self.loop)
+ f_exception = asyncio.Future(loop=self.loop)
f_exception.set_exception(RuntimeError())
- newf_exception = futures.Future(loop=self.loop)
+ newf_exception = asyncio.Future(loop=self.loop)
newf_exception._copy_state(f_exception)
self.assertTrue(newf_exception.done())
self.assertRaises(RuntimeError, newf_exception.result)
- f_cancelled = futures.Future(loop=self.loop)
+ f_cancelled = asyncio.Future(loop=self.loop)
f_cancelled.cancel()
- newf_cancelled = futures.Future(loop=self.loop)
+ newf_cancelled = asyncio.Future(loop=self.loop)
newf_cancelled._copy_state(f_cancelled)
self.assertTrue(newf_cancelled.cancelled())
def test_iter(self):
- fut = futures.Future(loop=self.loop)
+ fut = asyncio.Future(loop=self.loop)
def coro():
yield from fut
@unittest.mock.patch('asyncio.futures.logger')
def test_tb_logger_abandoned(self, m_log):
- fut = futures.Future(loop=self.loop)
+ fut = asyncio.Future(loop=self.loop)
del fut
self.assertFalse(m_log.error.called)
@unittest.mock.patch('asyncio.futures.logger')
def test_tb_logger_result_unretrieved(self, m_log):
- fut = futures.Future(loop=self.loop)
+ fut = asyncio.Future(loop=self.loop)
fut.set_result(42)
del fut
self.assertFalse(m_log.error.called)
@unittest.mock.patch('asyncio.futures.logger')
def test_tb_logger_result_retrieved(self, m_log):
- fut = futures.Future(loop=self.loop)
+ fut = asyncio.Future(loop=self.loop)
fut.set_result(42)
fut.result()
del fut
@unittest.mock.patch('asyncio.futures.logger')
def test_tb_logger_exception_unretrieved(self, m_log):
- fut = futures.Future(loop=self.loop)
+ fut = asyncio.Future(loop=self.loop)
fut.set_exception(RuntimeError('boom'))
del fut
test_utils.run_briefly(self.loop)
@unittest.mock.patch('asyncio.futures.logger')
def test_tb_logger_exception_retrieved(self, m_log):
- fut = futures.Future(loop=self.loop)
+ fut = asyncio.Future(loop=self.loop)
fut.set_exception(RuntimeError('boom'))
fut.exception()
del fut
@unittest.mock.patch('asyncio.futures.logger')
def test_tb_logger_exception_result_retrieved(self, m_log):
- fut = futures.Future(loop=self.loop)
+ fut = asyncio.Future(loop=self.loop)
fut.set_exception(RuntimeError('boom'))
self.assertRaises(RuntimeError, fut.result)
del fut
return (arg, threading.get_ident())
ex = concurrent.futures.ThreadPoolExecutor(1)
f1 = ex.submit(run, 'oi')
- f2 = futures.wrap_future(f1, loop=self.loop)
+ f2 = asyncio.wrap_future(f1, loop=self.loop)
res, ident = self.loop.run_until_complete(f2)
- self.assertIsInstance(f2, futures.Future)
+ self.assertIsInstance(f2, asyncio.Future)
self.assertEqual(res, 'oi')
self.assertNotEqual(ident, threading.get_ident())
def test_wrap_future_future(self):
- f1 = futures.Future(loop=self.loop)
- f2 = futures.wrap_future(f1)
+ f1 = asyncio.Future(loop=self.loop)
+ f2 = asyncio.wrap_future(f1)
self.assertIs(f1, f2)
@unittest.mock.patch('asyncio.futures.events')
return (arg, threading.get_ident())
ex = concurrent.futures.ThreadPoolExecutor(1)
f1 = ex.submit(run, 'oi')
- f2 = futures.wrap_future(f1)
+ f2 = asyncio.wrap_future(f1)
self.assertIs(m_events.get_event_loop.return_value, f2._loop)
def test_wrap_future_cancel(self):
f1 = concurrent.futures.Future()
- f2 = futures.wrap_future(f1, loop=self.loop)
+ f2 = asyncio.wrap_future(f1, loop=self.loop)
f2.cancel()
test_utils.run_briefly(self.loop)
self.assertTrue(f1.cancelled())
def test_wrap_future_cancel2(self):
f1 = concurrent.futures.Future()
- f2 = futures.wrap_future(f1, loop=self.loop)
+ f2 = asyncio.wrap_future(f1, loop=self.loop)
f1.set_result(42)
f2.cancel()
test_utils.run_briefly(self.loop)
def setUp(self):
self.loop = test_utils.TestLoop()
- events.set_event_loop(None)
+ asyncio.set_event_loop(None)
def tearDown(self):
self.loop.close()
return bag_appender
def _new_future(self):
- return futures.Future(loop=self.loop)
+ return asyncio.Future(loop=self.loop)
def test_callbacks_invoked_on_set_result(self):
bag = []
import unittest.mock
import re
-from asyncio import events
-from asyncio import futures
-from asyncio import locks
-from asyncio import tasks
+import asyncio
from asyncio import test_utils
def setUp(self):
self.loop = test_utils.TestLoop()
- events.set_event_loop(None)
+ asyncio.set_event_loop(None)
def tearDown(self):
self.loop.close()
def test_ctor_loop(self):
loop = unittest.mock.Mock()
- lock = locks.Lock(loop=loop)
+ lock = asyncio.Lock(loop=loop)
self.assertIs(lock._loop, loop)
- lock = locks.Lock(loop=self.loop)
+ lock = asyncio.Lock(loop=self.loop)
self.assertIs(lock._loop, self.loop)
def test_ctor_noloop(self):
try:
- events.set_event_loop(self.loop)
- lock = locks.Lock()
+ asyncio.set_event_loop(self.loop)
+ lock = asyncio.Lock()
self.assertIs(lock._loop, self.loop)
finally:
- events.set_event_loop(None)
+ asyncio.set_event_loop(None)
def test_repr(self):
- lock = locks.Lock(loop=self.loop)
+ lock = asyncio.Lock(loop=self.loop)
self.assertTrue(repr(lock).endswith('[unlocked]>'))
self.assertTrue(RGX_REPR.match(repr(lock)))
- @tasks.coroutine
+ @asyncio.coroutine
def acquire_lock():
yield from lock
self.assertTrue(RGX_REPR.match(repr(lock)))
def test_lock(self):
- lock = locks.Lock(loop=self.loop)
+ lock = asyncio.Lock(loop=self.loop)
- @tasks.coroutine
+ @asyncio.coroutine
def acquire_lock():
return (yield from lock)
self.assertFalse(lock.locked())
def test_acquire(self):
- lock = locks.Lock(loop=self.loop)
+ lock = asyncio.Lock(loop=self.loop)
result = []
self.assertTrue(self.loop.run_until_complete(lock.acquire()))
- @tasks.coroutine
+ @asyncio.coroutine
def c1(result):
if (yield from lock.acquire()):
result.append(1)
return True
- @tasks.coroutine
+ @asyncio.coroutine
def c2(result):
if (yield from lock.acquire()):
result.append(2)
return True
- @tasks.coroutine
+ @asyncio.coroutine
def c3(result):
if (yield from lock.acquire()):
result.append(3)
return True
- t1 = tasks.Task(c1(result), loop=self.loop)
- t2 = tasks.Task(c2(result), loop=self.loop)
+ t1 = asyncio.Task(c1(result), loop=self.loop)
+ t2 = asyncio.Task(c2(result), loop=self.loop)
test_utils.run_briefly(self.loop)
self.assertEqual([], result)
test_utils.run_briefly(self.loop)
self.assertEqual([1], result)
- t3 = tasks.Task(c3(result), loop=self.loop)
+ t3 = asyncio.Task(c3(result), loop=self.loop)
lock.release()
test_utils.run_briefly(self.loop)
self.assertTrue(t3.result())
def test_acquire_cancel(self):
- lock = locks.Lock(loop=self.loop)
+ lock = asyncio.Lock(loop=self.loop)
self.assertTrue(self.loop.run_until_complete(lock.acquire()))
- task = tasks.Task(lock.acquire(), loop=self.loop)
+ task = asyncio.Task(lock.acquire(), loop=self.loop)
self.loop.call_soon(task.cancel)
self.assertRaises(
- futures.CancelledError,
+ asyncio.CancelledError,
self.loop.run_until_complete, task)
self.assertFalse(lock._waiters)
# B's waiter; instead, it should move on to C's waiter.
# Setup: A has the lock, b and c are waiting.
- lock = locks.Lock(loop=self.loop)
+ lock = asyncio.Lock(loop=self.loop)
- @tasks.coroutine
+ @asyncio.coroutine
def lockit(name, blocker):
yield from lock.acquire()
try:
finally:
lock.release()
- fa = futures.Future(loop=self.loop)
- ta = tasks.Task(lockit('A', fa), loop=self.loop)
+ fa = asyncio.Future(loop=self.loop)
+ ta = asyncio.Task(lockit('A', fa), loop=self.loop)
test_utils.run_briefly(self.loop)
self.assertTrue(lock.locked())
- tb = tasks.Task(lockit('B', None), loop=self.loop)
+ tb = asyncio.Task(lockit('B', None), loop=self.loop)
test_utils.run_briefly(self.loop)
self.assertEqual(len(lock._waiters), 1)
- tc = tasks.Task(lockit('C', None), loop=self.loop)
+ tc = asyncio.Task(lockit('C', None), loop=self.loop)
test_utils.run_briefly(self.loop)
self.assertEqual(len(lock._waiters), 2)
self.assertTrue(tc.done())
def test_release_not_acquired(self):
- lock = locks.Lock(loop=self.loop)
+ lock = asyncio.Lock(loop=self.loop)
self.assertRaises(RuntimeError, lock.release)
def test_release_no_waiters(self):
- lock = locks.Lock(loop=self.loop)
+ lock = asyncio.Lock(loop=self.loop)
self.loop.run_until_complete(lock.acquire())
self.assertTrue(lock.locked())
self.assertFalse(lock.locked())
def test_context_manager(self):
- lock = locks.Lock(loop=self.loop)
+ lock = asyncio.Lock(loop=self.loop)
- @tasks.coroutine
+ @asyncio.coroutine
def acquire_lock():
return (yield from lock)
self.assertFalse(lock.locked())
def test_context_manager_no_yield(self):
- lock = locks.Lock(loop=self.loop)
+ lock = asyncio.Lock(loop=self.loop)
try:
with lock:
def setUp(self):
self.loop = test_utils.TestLoop()
- events.set_event_loop(None)
+ asyncio.set_event_loop(None)
def tearDown(self):
self.loop.close()
def test_ctor_loop(self):
loop = unittest.mock.Mock()
- ev = locks.Event(loop=loop)
+ ev = asyncio.Event(loop=loop)
self.assertIs(ev._loop, loop)
- ev = locks.Event(loop=self.loop)
+ ev = asyncio.Event(loop=self.loop)
self.assertIs(ev._loop, self.loop)
def test_ctor_noloop(self):
try:
- events.set_event_loop(self.loop)
- ev = locks.Event()
+ asyncio.set_event_loop(self.loop)
+ ev = asyncio.Event()
self.assertIs(ev._loop, self.loop)
finally:
- events.set_event_loop(None)
+ asyncio.set_event_loop(None)
def test_repr(self):
- ev = locks.Event(loop=self.loop)
+ ev = asyncio.Event(loop=self.loop)
self.assertTrue(repr(ev).endswith('[unset]>'))
match = RGX_REPR.match(repr(ev))
self.assertEqual(match.group('extras'), 'unset')
self.assertTrue(RGX_REPR.match(repr(ev)))
def test_wait(self):
- ev = locks.Event(loop=self.loop)
+ ev = asyncio.Event(loop=self.loop)
self.assertFalse(ev.is_set())
result = []
- @tasks.coroutine
+ @asyncio.coroutine
def c1(result):
if (yield from ev.wait()):
result.append(1)
- @tasks.coroutine
+ @asyncio.coroutine
def c2(result):
if (yield from ev.wait()):
result.append(2)
- @tasks.coroutine
+ @asyncio.coroutine
def c3(result):
if (yield from ev.wait()):
result.append(3)
- t1 = tasks.Task(c1(result), loop=self.loop)
- t2 = tasks.Task(c2(result), loop=self.loop)
+ t1 = asyncio.Task(c1(result), loop=self.loop)
+ t2 = asyncio.Task(c2(result), loop=self.loop)
test_utils.run_briefly(self.loop)
self.assertEqual([], result)
- t3 = tasks.Task(c3(result), loop=self.loop)
+ t3 = asyncio.Task(c3(result), loop=self.loop)
ev.set()
test_utils.run_briefly(self.loop)
self.assertIsNone(t3.result())
def test_wait_on_set(self):
- ev = locks.Event(loop=self.loop)
+ ev = asyncio.Event(loop=self.loop)
ev.set()
res = self.loop.run_until_complete(ev.wait())
self.assertTrue(res)
def test_wait_cancel(self):
- ev = locks.Event(loop=self.loop)
+ ev = asyncio.Event(loop=self.loop)
- wait = tasks.Task(ev.wait(), loop=self.loop)
+ wait = asyncio.Task(ev.wait(), loop=self.loop)
self.loop.call_soon(wait.cancel)
self.assertRaises(
- futures.CancelledError,
+ asyncio.CancelledError,
self.loop.run_until_complete, wait)
self.assertFalse(ev._waiters)
def test_clear(self):
- ev = locks.Event(loop=self.loop)
+ ev = asyncio.Event(loop=self.loop)
self.assertFalse(ev.is_set())
ev.set()
self.assertFalse(ev.is_set())
def test_clear_with_waiters(self):
- ev = locks.Event(loop=self.loop)
+ ev = asyncio.Event(loop=self.loop)
result = []
- @tasks.coroutine
+ @asyncio.coroutine
def c1(result):
if (yield from ev.wait()):
result.append(1)
return True
- t = tasks.Task(c1(result), loop=self.loop)
+ t = asyncio.Task(c1(result), loop=self.loop)
test_utils.run_briefly(self.loop)
self.assertEqual([], result)
def setUp(self):
self.loop = test_utils.TestLoop()
- events.set_event_loop(None)
+ asyncio.set_event_loop(None)
def tearDown(self):
self.loop.close()
def test_ctor_loop(self):
loop = unittest.mock.Mock()
- cond = locks.Condition(loop=loop)
+ cond = asyncio.Condition(loop=loop)
self.assertIs(cond._loop, loop)
- cond = locks.Condition(loop=self.loop)
+ cond = asyncio.Condition(loop=self.loop)
self.assertIs(cond._loop, self.loop)
def test_ctor_noloop(self):
try:
- events.set_event_loop(self.loop)
- cond = locks.Condition()
+ asyncio.set_event_loop(self.loop)
+ cond = asyncio.Condition()
self.assertIs(cond._loop, self.loop)
finally:
- events.set_event_loop(None)
+ asyncio.set_event_loop(None)
def test_wait(self):
- cond = locks.Condition(loop=self.loop)
+ cond = asyncio.Condition(loop=self.loop)
result = []
- @tasks.coroutine
+ @asyncio.coroutine
def c1(result):
yield from cond.acquire()
if (yield from cond.wait()):
result.append(1)
return True
- @tasks.coroutine
+ @asyncio.coroutine
def c2(result):
yield from cond.acquire()
if (yield from cond.wait()):
result.append(2)
return True
- @tasks.coroutine
+ @asyncio.coroutine
def c3(result):
yield from cond.acquire()
if (yield from cond.wait()):
result.append(3)
return True
- t1 = tasks.Task(c1(result), loop=self.loop)
- t2 = tasks.Task(c2(result), loop=self.loop)
- t3 = tasks.Task(c3(result), loop=self.loop)
+ t1 = asyncio.Task(c1(result), loop=self.loop)
+ t2 = asyncio.Task(c2(result), loop=self.loop)
+ t3 = asyncio.Task(c3(result), loop=self.loop)
test_utils.run_briefly(self.loop)
self.assertEqual([], result)
self.assertTrue(t3.result())
def test_wait_cancel(self):
- cond = locks.Condition(loop=self.loop)
+ cond = asyncio.Condition(loop=self.loop)
self.loop.run_until_complete(cond.acquire())
- wait = tasks.Task(cond.wait(), loop=self.loop)
+ wait = asyncio.Task(cond.wait(), loop=self.loop)
self.loop.call_soon(wait.cancel)
self.assertRaises(
- futures.CancelledError,
+ asyncio.CancelledError,
self.loop.run_until_complete, wait)
self.assertFalse(cond._waiters)
self.assertTrue(cond.locked())
def test_wait_unacquired(self):
- cond = locks.Condition(loop=self.loop)
+ cond = asyncio.Condition(loop=self.loop)
self.assertRaises(
RuntimeError,
self.loop.run_until_complete, cond.wait())
def test_wait_for(self):
- cond = locks.Condition(loop=self.loop)
+ cond = asyncio.Condition(loop=self.loop)
presult = False
def predicate():
result = []
- @tasks.coroutine
+ @asyncio.coroutine
def c1(result):
yield from cond.acquire()
if (yield from cond.wait_for(predicate)):
cond.release()
return True
- t = tasks.Task(c1(result), loop=self.loop)
+ t = asyncio.Task(c1(result), loop=self.loop)
test_utils.run_briefly(self.loop)
self.assertEqual([], result)
self.assertTrue(t.result())
def test_wait_for_unacquired(self):
- cond = locks.Condition(loop=self.loop)
+ cond = asyncio.Condition(loop=self.loop)
# predicate can return true immediately
res = self.loop.run_until_complete(cond.wait_for(lambda: [1, 2, 3]))
cond.wait_for(lambda: False))
def test_notify(self):
- cond = locks.Condition(loop=self.loop)
+ cond = asyncio.Condition(loop=self.loop)
result = []
- @tasks.coroutine
+ @asyncio.coroutine
def c1(result):
yield from cond.acquire()
if (yield from cond.wait()):
cond.release()
return True
- @tasks.coroutine
+ @asyncio.coroutine
def c2(result):
yield from cond.acquire()
if (yield from cond.wait()):
cond.release()
return True
- @tasks.coroutine
+ @asyncio.coroutine
def c3(result):
yield from cond.acquire()
if (yield from cond.wait()):
cond.release()
return True
- t1 = tasks.Task(c1(result), loop=self.loop)
- t2 = tasks.Task(c2(result), loop=self.loop)
- t3 = tasks.Task(c3(result), loop=self.loop)
+ t1 = asyncio.Task(c1(result), loop=self.loop)
+ t2 = asyncio.Task(c2(result), loop=self.loop)
+ t3 = asyncio.Task(c3(result), loop=self.loop)
test_utils.run_briefly(self.loop)
self.assertEqual([], result)
self.assertTrue(t3.result())
def test_notify_all(self):
- cond = locks.Condition(loop=self.loop)
+ cond = asyncio.Condition(loop=self.loop)
result = []
- @tasks.coroutine
+ @asyncio.coroutine
def c1(result):
yield from cond.acquire()
if (yield from cond.wait()):
cond.release()
return True
- @tasks.coroutine
+ @asyncio.coroutine
def c2(result):
yield from cond.acquire()
if (yield from cond.wait()):
cond.release()
return True
- t1 = tasks.Task(c1(result), loop=self.loop)
- t2 = tasks.Task(c2(result), loop=self.loop)
+ t1 = asyncio.Task(c1(result), loop=self.loop)
+ t2 = asyncio.Task(c2(result), loop=self.loop)
test_utils.run_briefly(self.loop)
self.assertEqual([], result)
self.assertTrue(t2.result())
def test_notify_unacquired(self):
- cond = locks.Condition(loop=self.loop)
+ cond = asyncio.Condition(loop=self.loop)
self.assertRaises(RuntimeError, cond.notify)
def test_notify_all_unacquired(self):
- cond = locks.Condition(loop=self.loop)
+ cond = asyncio.Condition(loop=self.loop)
self.assertRaises(RuntimeError, cond.notify_all)
def test_repr(self):
- cond = locks.Condition(loop=self.loop)
+ cond = asyncio.Condition(loop=self.loop)
self.assertTrue('unlocked' in repr(cond))
self.assertTrue(RGX_REPR.match(repr(cond)))
self.assertTrue(RGX_REPR.match(repr(cond)))
def test_context_manager(self):
- cond = locks.Condition(loop=self.loop)
+ cond = asyncio.Condition(loop=self.loop)
- @tasks.coroutine
+ @asyncio.coroutine
def acquire_cond():
return (yield from cond)
self.assertFalse(cond.locked())
def test_context_manager_no_yield(self):
- cond = locks.Condition(loop=self.loop)
+ cond = asyncio.Condition(loop=self.loop)
try:
with cond:
def setUp(self):
self.loop = test_utils.TestLoop()
- events.set_event_loop(None)
+ asyncio.set_event_loop(None)
def tearDown(self):
self.loop.close()
def test_ctor_loop(self):
loop = unittest.mock.Mock()
- sem = locks.Semaphore(loop=loop)
+ sem = asyncio.Semaphore(loop=loop)
self.assertIs(sem._loop, loop)
- sem = locks.Semaphore(loop=self.loop)
+ sem = asyncio.Semaphore(loop=self.loop)
self.assertIs(sem._loop, self.loop)
def test_ctor_noloop(self):
try:
- events.set_event_loop(self.loop)
- sem = locks.Semaphore()
+ asyncio.set_event_loop(self.loop)
+ sem = asyncio.Semaphore()
self.assertIs(sem._loop, self.loop)
finally:
- events.set_event_loop(None)
+ asyncio.set_event_loop(None)
def test_initial_value_zero(self):
- sem = locks.Semaphore(0, loop=self.loop)
+ sem = asyncio.Semaphore(0, loop=self.loop)
self.assertTrue(sem.locked())
def test_repr(self):
- sem = locks.Semaphore(loop=self.loop)
+ sem = asyncio.Semaphore(loop=self.loop)
self.assertTrue(repr(sem).endswith('[unlocked,value:1]>'))
self.assertTrue(RGX_REPR.match(repr(sem)))
self.assertTrue(RGX_REPR.match(repr(sem)))
def test_semaphore(self):
- sem = locks.Semaphore(loop=self.loop)
+ sem = asyncio.Semaphore(loop=self.loop)
self.assertEqual(1, sem._value)
- @tasks.coroutine
+ @asyncio.coroutine
def acquire_lock():
return (yield from sem)
self.assertEqual(1, sem._value)
def test_semaphore_value(self):
- self.assertRaises(ValueError, locks.Semaphore, -1)
+ self.assertRaises(ValueError, asyncio.Semaphore, -1)
def test_acquire(self):
- sem = locks.Semaphore(3, loop=self.loop)
+ sem = asyncio.Semaphore(3, loop=self.loop)
result = []
self.assertTrue(self.loop.run_until_complete(sem.acquire()))
self.assertTrue(self.loop.run_until_complete(sem.acquire()))
self.assertFalse(sem.locked())
- @tasks.coroutine
+ @asyncio.coroutine
def c1(result):
yield from sem.acquire()
result.append(1)
return True
- @tasks.coroutine
+ @asyncio.coroutine
def c2(result):
yield from sem.acquire()
result.append(2)
return True
- @tasks.coroutine
+ @asyncio.coroutine
def c3(result):
yield from sem.acquire()
result.append(3)
return True
- @tasks.coroutine
+ @asyncio.coroutine
def c4(result):
yield from sem.acquire()
result.append(4)
return True
- t1 = tasks.Task(c1(result), loop=self.loop)
- t2 = tasks.Task(c2(result), loop=self.loop)
- t3 = tasks.Task(c3(result), loop=self.loop)
+ t1 = asyncio.Task(c1(result), loop=self.loop)
+ t2 = asyncio.Task(c2(result), loop=self.loop)
+ t3 = asyncio.Task(c3(result), loop=self.loop)
test_utils.run_briefly(self.loop)
self.assertEqual([1], result)
self.assertEqual(2, len(sem._waiters))
self.assertEqual(0, sem._value)
- t4 = tasks.Task(c4(result), loop=self.loop)
+ t4 = asyncio.Task(c4(result), loop=self.loop)
sem.release()
sem.release()
sem.release()
def test_acquire_cancel(self):
- sem = locks.Semaphore(loop=self.loop)
+ sem = asyncio.Semaphore(loop=self.loop)
self.loop.run_until_complete(sem.acquire())
- acquire = tasks.Task(sem.acquire(), loop=self.loop)
+ acquire = asyncio.Task(sem.acquire(), loop=self.loop)
self.loop.call_soon(acquire.cancel)
self.assertRaises(
- futures.CancelledError,
+ asyncio.CancelledError,
self.loop.run_until_complete, acquire)
self.assertFalse(sem._waiters)
def test_release_not_acquired(self):
- sem = locks.BoundedSemaphore(loop=self.loop)
+ sem = asyncio.BoundedSemaphore(loop=self.loop)
self.assertRaises(ValueError, sem.release)
def test_release_no_waiters(self):
- sem = locks.Semaphore(loop=self.loop)
+ sem = asyncio.Semaphore(loop=self.loop)
self.loop.run_until_complete(sem.acquire())
self.assertTrue(sem.locked())
self.assertFalse(sem.locked())
def test_context_manager(self):
- sem = locks.Semaphore(2, loop=self.loop)
+ sem = asyncio.Semaphore(2, loop=self.loop)
- @tasks.coroutine
+ @asyncio.coroutine
def acquire_lock():
return (yield from sem)
import unittest.mock
import asyncio
-from asyncio.proactor_events import BaseProactorEventLoop
from asyncio.proactor_events import _ProactorSocketTransport
from asyncio.proactor_events import _ProactorWritePipeTransport
from asyncio.proactor_events import _ProactorDuplexPipeTransport
self.ssock, self.csock = unittest.mock.Mock(), unittest.mock.Mock()
- class EventLoop(BaseProactorEventLoop):
+ class EventLoop(asyncio.BaseProactorEventLoop):
def _socketpair(s):
return (self.ssock, self.csock)
self.loop = EventLoop(self.proactor)
- @unittest.mock.patch.object(BaseProactorEventLoop, 'call_soon')
- @unittest.mock.patch.object(BaseProactorEventLoop, '_socketpair')
+ @unittest.mock.patch.object(asyncio.BaseProactorEventLoop, 'call_soon')
+ @unittest.mock.patch.object(asyncio.BaseProactorEventLoop, '_socketpair')
def test_ctor(self, socketpair, call_soon):
ssock, csock = socketpair.return_value = (
unittest.mock.Mock(), unittest.mock.Mock())
- loop = BaseProactorEventLoop(self.proactor)
+ loop = asyncio.BaseProactorEventLoop(self.proactor)
self.assertIs(loop._ssock, ssock)
self.assertIs(loop._csock, csock)
self.assertEqual(loop._internal_fds, 1)
def test_socketpair(self):
self.assertRaises(
- NotImplementedError, BaseProactorEventLoop, self.proactor)
+ NotImplementedError, asyncio.BaseProactorEventLoop, self.proactor)
def test_make_socket_transport(self):
tr = self.loop._make_socket_transport(self.sock, unittest.mock.Mock())
import unittest
import unittest.mock
-from asyncio import events
-from asyncio import futures
-from asyncio import locks
-from asyncio import queues
-from asyncio import tasks
+import asyncio
from asyncio import test_utils
def setUp(self):
self.loop = test_utils.TestLoop()
- events.set_event_loop(None)
+ asyncio.set_event_loop(None)
def tearDown(self):
self.loop.close()
loop = test_utils.TestLoop(gen)
self.addCleanup(loop.close)
- q = queues.Queue(loop=loop)
+ q = asyncio.Queue(loop=loop)
self.assertTrue(fn(q).startswith('<Queue'), fn(q))
id_is_present = hex(id(q)) in fn(q)
self.assertEqual(expect_id, id_is_present)
- @tasks.coroutine
+ @asyncio.coroutine
def add_getter():
- q = queues.Queue(loop=loop)
+ q = asyncio.Queue(loop=loop)
# Start a task that waits to get.
- tasks.Task(q.get(), loop=loop)
+ asyncio.Task(q.get(), loop=loop)
# Let it start waiting.
- yield from tasks.sleep(0.1, loop=loop)
+ yield from asyncio.sleep(0.1, loop=loop)
self.assertTrue('_getters[1]' in fn(q))
# resume q.get coroutine to finish generator
q.put_nowait(0)
loop.run_until_complete(add_getter())
- @tasks.coroutine
+ @asyncio.coroutine
def add_putter():
- q = queues.Queue(maxsize=1, loop=loop)
+ q = asyncio.Queue(maxsize=1, loop=loop)
q.put_nowait(1)
# Start a task that waits to put.
- tasks.Task(q.put(2), loop=loop)
+ asyncio.Task(q.put(2), loop=loop)
# Let it start waiting.
- yield from tasks.sleep(0.1, loop=loop)
+ yield from asyncio.sleep(0.1, loop=loop)
self.assertTrue('_putters[1]' in fn(q))
# resume q.put coroutine to finish generator
q.get_nowait()
loop.run_until_complete(add_putter())
- q = queues.Queue(loop=loop)
+ q = asyncio.Queue(loop=loop)
q.put_nowait(1)
self.assertTrue('_queue=[1]' in fn(q))
def test_ctor_loop(self):
loop = unittest.mock.Mock()
- q = queues.Queue(loop=loop)
+ q = asyncio.Queue(loop=loop)
self.assertIs(q._loop, loop)
- q = queues.Queue(loop=self.loop)
+ q = asyncio.Queue(loop=self.loop)
self.assertIs(q._loop, self.loop)
def test_ctor_noloop(self):
try:
- events.set_event_loop(self.loop)
- q = queues.Queue()
+ asyncio.set_event_loop(self.loop)
+ q = asyncio.Queue()
self.assertIs(q._loop, self.loop)
finally:
- events.set_event_loop(None)
+ asyncio.set_event_loop(None)
def test_repr(self):
self._test_repr_or_str(repr, True)
self._test_repr_or_str(str, False)
def test_empty(self):
- q = queues.Queue(loop=self.loop)
+ q = asyncio.Queue(loop=self.loop)
self.assertTrue(q.empty())
q.put_nowait(1)
self.assertFalse(q.empty())
self.assertTrue(q.empty())
def test_full(self):
- q = queues.Queue(loop=self.loop)
+ q = asyncio.Queue(loop=self.loop)
self.assertFalse(q.full())
- q = queues.Queue(maxsize=1, loop=self.loop)
+ q = asyncio.Queue(maxsize=1, loop=self.loop)
q.put_nowait(1)
self.assertTrue(q.full())
def test_order(self):
- q = queues.Queue(loop=self.loop)
+ q = asyncio.Queue(loop=self.loop)
for i in [1, 3, 2]:
q.put_nowait(i)
loop = test_utils.TestLoop(gen)
self.addCleanup(loop.close)
- q = queues.Queue(maxsize=2, loop=loop)
+ q = asyncio.Queue(maxsize=2, loop=loop)
self.assertEqual(2, q.maxsize)
have_been_put = []
- @tasks.coroutine
+ @asyncio.coroutine
def putter():
for i in range(3):
yield from q.put(i)
have_been_put.append(i)
return True
- @tasks.coroutine
+ @asyncio.coroutine
def test():
- t = tasks.Task(putter(), loop=loop)
- yield from tasks.sleep(0.01, loop=loop)
+ t = asyncio.Task(putter(), loop=loop)
+ yield from asyncio.sleep(0.01, loop=loop)
# The putter is blocked after putting two items.
self.assertEqual([0, 1], have_been_put)
self.assertEqual(0, q.get_nowait())
# Let the putter resume and put last item.
- yield from tasks.sleep(0.01, loop=loop)
+ yield from asyncio.sleep(0.01, loop=loop)
self.assertEqual([0, 1, 2], have_been_put)
self.assertEqual(1, q.get_nowait())
self.assertEqual(2, q.get_nowait())
class QueueGetTests(_QueueTestBase):
def test_blocking_get(self):
- q = queues.Queue(loop=self.loop)
+ q = asyncio.Queue(loop=self.loop)
q.put_nowait(1)
- @tasks.coroutine
+ @asyncio.coroutine
def queue_get():
return (yield from q.get())
self.assertEqual(1, res)
def test_get_with_putters(self):
- q = queues.Queue(1, loop=self.loop)
+ q = asyncio.Queue(1, loop=self.loop)
q.put_nowait(1)
- waiter = futures.Future(loop=self.loop)
+ waiter = asyncio.Future(loop=self.loop)
q._putters.append((2, waiter))
res = self.loop.run_until_complete(q.get())
loop = test_utils.TestLoop(gen)
self.addCleanup(loop.close)
- q = queues.Queue(loop=loop)
- started = locks.Event(loop=loop)
+ q = asyncio.Queue(loop=loop)
+ started = asyncio.Event(loop=loop)
finished = False
- @tasks.coroutine
+ @asyncio.coroutine
def queue_get():
nonlocal finished
started.set()
finished = True
return res
- @tasks.coroutine
+ @asyncio.coroutine
def queue_put():
loop.call_later(0.01, q.put_nowait, 1)
- queue_get_task = tasks.Task(queue_get(), loop=loop)
+ queue_get_task = asyncio.Task(queue_get(), loop=loop)
yield from started.wait()
self.assertFalse(finished)
res = yield from queue_get_task
self.assertAlmostEqual(0.01, loop.time())
def test_nonblocking_get(self):
- q = queues.Queue(loop=self.loop)
+ q = asyncio.Queue(loop=self.loop)
q.put_nowait(1)
self.assertEqual(1, q.get_nowait())
def test_nonblocking_get_exception(self):
- q = queues.Queue(loop=self.loop)
- self.assertRaises(queues.Empty, q.get_nowait)
+ q = asyncio.Queue(loop=self.loop)
+ self.assertRaises(asyncio.Empty, q.get_nowait)
def test_get_cancelled(self):
loop = test_utils.TestLoop(gen)
self.addCleanup(loop.close)
- q = queues.Queue(loop=loop)
+ q = asyncio.Queue(loop=loop)
- @tasks.coroutine
+ @asyncio.coroutine
def queue_get():
- return (yield from tasks.wait_for(q.get(), 0.051, loop=loop))
+ return (yield from asyncio.wait_for(q.get(), 0.051, loop=loop))
- @tasks.coroutine
+ @asyncio.coroutine
def test():
- get_task = tasks.Task(queue_get(), loop=loop)
- yield from tasks.sleep(0.01, loop=loop) # let the task start
+ get_task = asyncio.Task(queue_get(), loop=loop)
+ yield from asyncio.sleep(0.01, loop=loop) # let the task start
q.put_nowait(1)
return (yield from get_task)
self.assertAlmostEqual(0.06, loop.time())
def test_get_cancelled_race(self):
- q = queues.Queue(loop=self.loop)
+ q = asyncio.Queue(loop=self.loop)
- t1 = tasks.Task(q.get(), loop=self.loop)
- t2 = tasks.Task(q.get(), loop=self.loop)
+ t1 = asyncio.Task(q.get(), loop=self.loop)
+ t2 = asyncio.Task(q.get(), loop=self.loop)
test_utils.run_briefly(self.loop)
t1.cancel()
self.assertEqual(t2.result(), 'a')
def test_get_with_waiting_putters(self):
- q = queues.Queue(loop=self.loop, maxsize=1)
- tasks.Task(q.put('a'), loop=self.loop)
- tasks.Task(q.put('b'), loop=self.loop)
+ q = asyncio.Queue(loop=self.loop, maxsize=1)
+ asyncio.Task(q.put('a'), loop=self.loop)
+ asyncio.Task(q.put('b'), loop=self.loop)
test_utils.run_briefly(self.loop)
self.assertEqual(self.loop.run_until_complete(q.get()), 'a')
self.assertEqual(self.loop.run_until_complete(q.get()), 'b')
class QueuePutTests(_QueueTestBase):
def test_blocking_put(self):
- q = queues.Queue(loop=self.loop)
+ q = asyncio.Queue(loop=self.loop)
- @tasks.coroutine
+ @asyncio.coroutine
def queue_put():
# No maxsize, won't block.
yield from q.put(1)
loop = test_utils.TestLoop(gen)
self.addCleanup(loop.close)
- q = queues.Queue(maxsize=1, loop=loop)
- started = locks.Event(loop=loop)
+ q = asyncio.Queue(maxsize=1, loop=loop)
+ started = asyncio.Event(loop=loop)
finished = False
- @tasks.coroutine
+ @asyncio.coroutine
def queue_put():
nonlocal finished
started.set()
yield from q.put(2)
finished = True
- @tasks.coroutine
+ @asyncio.coroutine
def queue_get():
loop.call_later(0.01, q.get_nowait)
- queue_put_task = tasks.Task(queue_put(), loop=loop)
+ queue_put_task = asyncio.Task(queue_put(), loop=loop)
yield from started.wait()
self.assertFalse(finished)
yield from queue_put_task
self.assertAlmostEqual(0.01, loop.time())
def test_nonblocking_put(self):
- q = queues.Queue(loop=self.loop)
+ q = asyncio.Queue(loop=self.loop)
q.put_nowait(1)
self.assertEqual(1, q.get_nowait())
def test_nonblocking_put_exception(self):
- q = queues.Queue(maxsize=1, loop=self.loop)
+ q = asyncio.Queue(maxsize=1, loop=self.loop)
q.put_nowait(1)
- self.assertRaises(queues.Full, q.put_nowait, 2)
+ self.assertRaises(asyncio.Full, q.put_nowait, 2)
def test_put_cancelled(self):
- q = queues.Queue(loop=self.loop)
+ q = asyncio.Queue(loop=self.loop)
- @tasks.coroutine
+ @asyncio.coroutine
def queue_put():
yield from q.put(1)
return True
- @tasks.coroutine
+ @asyncio.coroutine
def test():
return (yield from q.get())
- t = tasks.Task(queue_put(), loop=self.loop)
+ t = asyncio.Task(queue_put(), loop=self.loop)
self.assertEqual(1, self.loop.run_until_complete(test()))
self.assertTrue(t.done())
self.assertTrue(t.result())
def test_put_cancelled_race(self):
- q = queues.Queue(loop=self.loop, maxsize=1)
+ q = asyncio.Queue(loop=self.loop, maxsize=1)
- tasks.Task(q.put('a'), loop=self.loop)
- tasks.Task(q.put('c'), loop=self.loop)
- t = tasks.Task(q.put('b'), loop=self.loop)
+ asyncio.Task(q.put('a'), loop=self.loop)
+ asyncio.Task(q.put('c'), loop=self.loop)
+ t = asyncio.Task(q.put('b'), loop=self.loop)
test_utils.run_briefly(self.loop)
t.cancel()
self.assertEqual(q.get_nowait(), 'c')
def test_put_with_waiting_getters(self):
- q = queues.Queue(loop=self.loop)
- t = tasks.Task(q.get(), loop=self.loop)
+ q = asyncio.Queue(loop=self.loop)
+ t = asyncio.Task(q.get(), loop=self.loop)
test_utils.run_briefly(self.loop)
self.loop.run_until_complete(q.put('a'))
self.assertEqual(self.loop.run_until_complete(t), 'a')
class LifoQueueTests(_QueueTestBase):
def test_order(self):
- q = queues.LifoQueue(loop=self.loop)
+ q = asyncio.LifoQueue(loop=self.loop)
for i in [1, 3, 2]:
q.put_nowait(i)
class PriorityQueueTests(_QueueTestBase):
def test_order(self):
- q = queues.PriorityQueue(loop=self.loop)
+ q = asyncio.PriorityQueue(loop=self.loop)
for i in [1, 3, 2]:
q.put_nowait(i)
class JoinableQueueTests(_QueueTestBase):
def test_task_done_underflow(self):
- q = queues.JoinableQueue(loop=self.loop)
+ q = asyncio.JoinableQueue(loop=self.loop)
self.assertRaises(ValueError, q.task_done)
def test_task_done(self):
- q = queues.JoinableQueue(loop=self.loop)
+ q = asyncio.JoinableQueue(loop=self.loop)
for i in range(100):
q.put_nowait(i)
# Join the queue and assert all items have been processed.
running = True
- @tasks.coroutine
+ @asyncio.coroutine
def worker():
nonlocal accumulator
accumulator += item
q.task_done()
- @tasks.coroutine
+ @asyncio.coroutine
def test():
for _ in range(2):
- tasks.Task(worker(), loop=self.loop)
+ asyncio.Task(worker(), loop=self.loop)
yield from q.join()
q.put_nowait(0)
def test_join_empty_queue(self):
- q = queues.JoinableQueue(loop=self.loop)
+ q = asyncio.JoinableQueue(loop=self.loop)
# Test that a queue join()s successfully, and before anything else
# (done twice for insurance).
- @tasks.coroutine
+ @asyncio.coroutine
def join():
yield from q.join()
yield from q.join()
self.loop.run_until_complete(join())
def test_format(self):
- q = queues.JoinableQueue(loop=self.loop)
+ q = asyncio.JoinableQueue(loop=self.loop)
self.assertEqual(q._format(), 'maxsize=0')
q._unfinished_tasks = 2
except ImportError:
ssl = None
-from asyncio import futures
+import asyncio
from asyncio import selectors
from asyncio import test_utils
-from asyncio.protocols import DatagramProtocol, Protocol
-from asyncio.selector_events import BaseSelectorEventLoop
from asyncio.selector_events import _SelectorTransport
from asyncio.selector_events import _SelectorSslTransport
from asyncio.selector_events import _SelectorSocketTransport
from asyncio.selector_events import _SelectorDatagramTransport
-class TestBaseSelectorEventLoop(BaseSelectorEventLoop):
+class TestBaseSelectorEventLoop(asyncio.BaseSelectorEventLoop):
def _make_self_pipe(self):
self._ssock = unittest.mock.Mock()
self.loop._sock_recv = unittest.mock.Mock()
f = self.loop.sock_recv(sock, 1024)
- self.assertIsInstance(f, futures.Future)
+ self.assertIsInstance(f, asyncio.Future)
self.loop._sock_recv.assert_called_with(f, False, sock, 1024)
def test__sock_recv_canceled_fut(self):
sock = unittest.mock.Mock()
- f = futures.Future(loop=self.loop)
+ f = asyncio.Future(loop=self.loop)
f.cancel()
self.loop._sock_recv(f, False, sock, 1024)
sock = unittest.mock.Mock()
sock.fileno.return_value = 10
- f = futures.Future(loop=self.loop)
+ f = asyncio.Future(loop=self.loop)
f.cancel()
self.loop.remove_reader = unittest.mock.Mock()
self.assertEqual((10,), self.loop.remove_reader.call_args[0])
def test__sock_recv_tryagain(self):
- f = futures.Future(loop=self.loop)
+ f = asyncio.Future(loop=self.loop)
sock = unittest.mock.Mock()
sock.fileno.return_value = 10
sock.recv.side_effect = BlockingIOError
self.loop.add_reader.call_args[0])
def test__sock_recv_exception(self):
- f = futures.Future(loop=self.loop)
+ f = asyncio.Future(loop=self.loop)
sock = unittest.mock.Mock()
sock.fileno.return_value = 10
err = sock.recv.side_effect = OSError()
self.loop._sock_sendall = unittest.mock.Mock()
f = self.loop.sock_sendall(sock, b'data')
- self.assertIsInstance(f, futures.Future)
+ self.assertIsInstance(f, asyncio.Future)
self.assertEqual(
(f, False, sock, b'data'),
self.loop._sock_sendall.call_args[0])
self.loop._sock_sendall = unittest.mock.Mock()
f = self.loop.sock_sendall(sock, b'')
- self.assertIsInstance(f, futures.Future)
+ self.assertIsInstance(f, asyncio.Future)
self.assertTrue(f.done())
self.assertIsNone(f.result())
self.assertFalse(self.loop._sock_sendall.called)
def test__sock_sendall_canceled_fut(self):
sock = unittest.mock.Mock()
- f = futures.Future(loop=self.loop)
+ f = asyncio.Future(loop=self.loop)
f.cancel()
self.loop._sock_sendall(f, False, sock, b'data')
sock = unittest.mock.Mock()
sock.fileno.return_value = 10
- f = futures.Future(loop=self.loop)
+ f = asyncio.Future(loop=self.loop)
f.cancel()
self.loop.remove_writer = unittest.mock.Mock()
self.assertEqual((10,), self.loop.remove_writer.call_args[0])
def test__sock_sendall_tryagain(self):
- f = futures.Future(loop=self.loop)
+ f = asyncio.Future(loop=self.loop)
sock = unittest.mock.Mock()
sock.fileno.return_value = 10
sock.send.side_effect = BlockingIOError
self.loop.add_writer.call_args[0])
def test__sock_sendall_interrupted(self):
- f = futures.Future(loop=self.loop)
+ f = asyncio.Future(loop=self.loop)
sock = unittest.mock.Mock()
sock.fileno.return_value = 10
sock.send.side_effect = InterruptedError
self.loop.add_writer.call_args[0])
def test__sock_sendall_exception(self):
- f = futures.Future(loop=self.loop)
+ f = asyncio.Future(loop=self.loop)
sock = unittest.mock.Mock()
sock.fileno.return_value = 10
err = sock.send.side_effect = OSError()
def test__sock_sendall(self):
sock = unittest.mock.Mock()
- f = futures.Future(loop=self.loop)
+ f = asyncio.Future(loop=self.loop)
sock.fileno.return_value = 10
sock.send.return_value = 4
def test__sock_sendall_partial(self):
sock = unittest.mock.Mock()
- f = futures.Future(loop=self.loop)
+ f = asyncio.Future(loop=self.loop)
sock.fileno.return_value = 10
sock.send.return_value = 2
def test__sock_sendall_none(self):
sock = unittest.mock.Mock()
- f = futures.Future(loop=self.loop)
+ f = asyncio.Future(loop=self.loop)
sock.fileno.return_value = 10
sock.send.return_value = 0
self.loop._sock_connect = unittest.mock.Mock()
f = self.loop.sock_connect(sock, ('127.0.0.1', 8080))
- self.assertIsInstance(f, futures.Future)
+ self.assertIsInstance(f, asyncio.Future)
self.assertEqual(
(f, False, sock, ('127.0.0.1', 8080)),
self.loop._sock_connect.call_args[0])
def test__sock_connect(self):
- f = futures.Future(loop=self.loop)
+ f = asyncio.Future(loop=self.loop)
sock = unittest.mock.Mock()
sock.fileno.return_value = 10
def test__sock_connect_canceled_fut(self):
sock = unittest.mock.Mock()
- f = futures.Future(loop=self.loop)
+ f = asyncio.Future(loop=self.loop)
f.cancel()
self.loop._sock_connect(f, False, sock, ('127.0.0.1', 8080))
sock = unittest.mock.Mock()
sock.fileno.return_value = 10
- f = futures.Future(loop=self.loop)
+ f = asyncio.Future(loop=self.loop)
f.cancel()
self.loop.remove_writer = unittest.mock.Mock()
self.assertEqual((10,), self.loop.remove_writer.call_args[0])
def test__sock_connect_tryagain(self):
- f = futures.Future(loop=self.loop)
+ f = asyncio.Future(loop=self.loop)
sock = unittest.mock.Mock()
sock.fileno.return_value = 10
sock.getsockopt.return_value = errno.EAGAIN
self.loop.add_writer.call_args[0])
def test__sock_connect_exception(self):
- f = futures.Future(loop=self.loop)
+ f = asyncio.Future(loop=self.loop)
sock = unittest.mock.Mock()
sock.fileno.return_value = 10
sock.getsockopt.return_value = errno.ENOTCONN
self.loop._sock_accept = unittest.mock.Mock()
f = self.loop.sock_accept(sock)
- self.assertIsInstance(f, futures.Future)
+ self.assertIsInstance(f, asyncio.Future)
self.assertEqual(
(f, False, sock), self.loop._sock_accept.call_args[0])
def test__sock_accept(self):
- f = futures.Future(loop=self.loop)
+ f = asyncio.Future(loop=self.loop)
conn = unittest.mock.Mock()
def test__sock_accept_canceled_fut(self):
sock = unittest.mock.Mock()
- f = futures.Future(loop=self.loop)
+ f = asyncio.Future(loop=self.loop)
f.cancel()
self.loop._sock_accept(f, False, sock)
sock = unittest.mock.Mock()
sock.fileno.return_value = 10
- f = futures.Future(loop=self.loop)
+ f = asyncio.Future(loop=self.loop)
f.cancel()
self.loop.remove_reader = unittest.mock.Mock()
self.assertEqual((10,), self.loop.remove_reader.call_args[0])
def test__sock_accept_tryagain(self):
- f = futures.Future(loop=self.loop)
+ f = asyncio.Future(loop=self.loop)
sock = unittest.mock.Mock()
sock.fileno.return_value = 10
sock.accept.side_effect = BlockingIOError
self.loop.add_reader.call_args[0])
def test__sock_accept_exception(self):
- f = futures.Future(loop=self.loop)
+ f = asyncio.Future(loop=self.loop)
sock = unittest.mock.Mock()
sock.fileno.return_value = 10
err = sock.accept.side_effect = OSError()
def setUp(self):
self.loop = test_utils.TestLoop()
- self.protocol = test_utils.make_test_protocol(Protocol)
+ self.protocol = test_utils.make_test_protocol(asyncio.Protocol)
self.sock = unittest.mock.Mock(socket.socket)
self.sock.fileno.return_value = 7
def setUp(self):
self.loop = test_utils.TestLoop()
- self.protocol = test_utils.make_test_protocol(Protocol)
+ self.protocol = test_utils.make_test_protocol(asyncio.Protocol)
self.sock = unittest.mock.Mock(socket.socket)
self.sock_fd = self.sock.fileno.return_value = 7
self.protocol.connection_made.assert_called_with(tr)
def test_ctor_with_waiter(self):
- fut = futures.Future(loop=self.loop)
+ fut = asyncio.Future(loop=self.loop)
_SelectorSocketTransport(
self.loop, self.sock, self.protocol, fut)
def setUp(self):
self.loop = test_utils.TestLoop()
- self.protocol = test_utils.make_test_protocol(Protocol)
+ self.protocol = test_utils.make_test_protocol(asyncio.Protocol)
self.sock = unittest.mock.Mock(socket.socket)
self.sock.fileno.return_value = 7
self.sslsock = unittest.mock.Mock()
return transport
def test_on_handshake(self):
- waiter = futures.Future(loop=self.loop)
+ waiter = asyncio.Future(loop=self.loop)
tr = _SelectorSslTransport(
self.loop, self.sock, self.protocol, self.sslcontext,
waiter=waiter)
self.sslsock.do_handshake.side_effect = exc
transport = _SelectorSslTransport(
self.loop, self.sock, self.protocol, self.sslcontext)
- transport._waiter = futures.Future(loop=self.loop)
+ transport._waiter = asyncio.Future(loop=self.loop)
transport._on_handshake()
self.assertTrue(self.sslsock.close.called)
self.assertTrue(transport._waiter.done())
def test_on_handshake_base_exc(self):
transport = _SelectorSslTransport(
self.loop, self.sock, self.protocol, self.sslcontext)
- transport._waiter = futures.Future(loop=self.loop)
+ transport._waiter = asyncio.Future(loop=self.loop)
exc = BaseException()
self.sslsock.do_handshake.side_effect = exc
self.assertRaises(BaseException, transport._on_handshake)
def setUp(self):
self.loop = test_utils.TestLoop()
- self.protocol = test_utils.make_test_protocol(DatagramProtocol)
+ self.protocol = test_utils.make_test_protocol(asyncio.DatagramProtocol)
self.sock = unittest.mock.Mock(spec_set=socket.socket)
self.sock.fileno.return_value = 7
except ImportError:
ssl = None
-from asyncio import events
-from asyncio import streams
-from asyncio import tasks
+import asyncio
from asyncio import test_utils
DATA = b'line1\nline2\nline3\n'
def setUp(self):
- self.loop = events.new_event_loop()
- events.set_event_loop(None)
+ self.loop = asyncio.new_event_loop()
+ asyncio.set_event_loop(None)
def tearDown(self):
# just in case if we have transport close callbacks
@unittest.mock.patch('asyncio.streams.events')
def test_ctor_global_loop(self, m_events):
- stream = streams.StreamReader()
+ stream = asyncio.StreamReader()
self.assertIs(stream._loop, m_events.get_event_loop.return_value)
def test_open_connection(self):
with test_utils.run_test_server() as httpd:
- f = streams.open_connection(*httpd.address, loop=self.loop)
+ f = asyncio.open_connection(*httpd.address, loop=self.loop)
reader, writer = self.loop.run_until_complete(f)
writer.write(b'GET / HTTP/1.0\r\n\r\n')
f = reader.readline()
def test_open_connection_no_loop_ssl(self):
with test_utils.run_test_server(use_ssl=True) as httpd:
try:
- events.set_event_loop(self.loop)
- f = streams.open_connection(*httpd.address,
+ asyncio.set_event_loop(self.loop)
+ f = asyncio.open_connection(*httpd.address,
ssl=test_utils.dummy_ssl_context())
reader, writer = self.loop.run_until_complete(f)
finally:
- events.set_event_loop(None)
+ asyncio.set_event_loop(None)
writer.write(b'GET / HTTP/1.0\r\n\r\n')
f = reader.read()
data = self.loop.run_until_complete(f)
def test_open_connection_error(self):
with test_utils.run_test_server() as httpd:
- f = streams.open_connection(*httpd.address, loop=self.loop)
+ f = asyncio.open_connection(*httpd.address, loop=self.loop)
reader, writer = self.loop.run_until_complete(f)
writer._protocol.connection_lost(ZeroDivisionError())
f = reader.read()
test_utils.run_briefly(self.loop)
def test_feed_empty_data(self):
- stream = streams.StreamReader(loop=self.loop)
+ stream = asyncio.StreamReader(loop=self.loop)
stream.feed_data(b'')
self.assertEqual(0, stream._byte_count)
def test_feed_data_byte_count(self):
- stream = streams.StreamReader(loop=self.loop)
+ stream = asyncio.StreamReader(loop=self.loop)
stream.feed_data(self.DATA)
self.assertEqual(len(self.DATA), stream._byte_count)
def test_read_zero(self):
# Read zero bytes.
- stream = streams.StreamReader(loop=self.loop)
+ stream = asyncio.StreamReader(loop=self.loop)
stream.feed_data(self.DATA)
data = self.loop.run_until_complete(stream.read(0))
def test_read(self):
# Read bytes.
- stream = streams.StreamReader(loop=self.loop)
- read_task = tasks.Task(stream.read(30), loop=self.loop)
+ stream = asyncio.StreamReader(loop=self.loop)
+ read_task = asyncio.Task(stream.read(30), loop=self.loop)
def cb():
stream.feed_data(self.DATA)
def test_read_line_breaks(self):
# Read bytes without line breaks.
- stream = streams.StreamReader(loop=self.loop)
+ stream = asyncio.StreamReader(loop=self.loop)
stream.feed_data(b'line1')
stream.feed_data(b'line2')
def test_read_eof(self):
# Read bytes, stop at eof.
- stream = streams.StreamReader(loop=self.loop)
- read_task = tasks.Task(stream.read(1024), loop=self.loop)
+ stream = asyncio.StreamReader(loop=self.loop)
+ read_task = asyncio.Task(stream.read(1024), loop=self.loop)
def cb():
stream.feed_eof()
def test_read_until_eof(self):
# Read all bytes until eof.
- stream = streams.StreamReader(loop=self.loop)
- read_task = tasks.Task(stream.read(-1), loop=self.loop)
+ stream = asyncio.StreamReader(loop=self.loop)
+ read_task = asyncio.Task(stream.read(-1), loop=self.loop)
def cb():
stream.feed_data(b'chunk1\n')
self.assertFalse(stream._byte_count)
def test_read_exception(self):
- stream = streams.StreamReader(loop=self.loop)
+ stream = asyncio.StreamReader(loop=self.loop)
stream.feed_data(b'line\n')
data = self.loop.run_until_complete(stream.read(2))
def test_readline(self):
# Read one line.
- stream = streams.StreamReader(loop=self.loop)
+ stream = asyncio.StreamReader(loop=self.loop)
stream.feed_data(b'chunk1 ')
- read_task = tasks.Task(stream.readline(), loop=self.loop)
+ read_task = asyncio.Task(stream.readline(), loop=self.loop)
def cb():
stream.feed_data(b'chunk2 ')
self.assertEqual(len(b'\n chunk4')-1, stream._byte_count)
def test_readline_limit_with_existing_data(self):
- stream = streams.StreamReader(3, loop=self.loop)
+ stream = asyncio.StreamReader(3, loop=self.loop)
stream.feed_data(b'li')
stream.feed_data(b'ne1\nline2\n')
ValueError, self.loop.run_until_complete, stream.readline())
self.assertEqual([b'line2\n'], list(stream._buffer))
- stream = streams.StreamReader(3, loop=self.loop)
+ stream = asyncio.StreamReader(3, loop=self.loop)
stream.feed_data(b'li')
stream.feed_data(b'ne1')
stream.feed_data(b'li')
self.assertEqual(2, stream._byte_count)
def test_readline_limit(self):
- stream = streams.StreamReader(7, loop=self.loop)
+ stream = asyncio.StreamReader(7, loop=self.loop)
def cb():
stream.feed_data(b'chunk1')
self.assertEqual(7, stream._byte_count)
def test_readline_line_byte_count(self):
- stream = streams.StreamReader(loop=self.loop)
+ stream = asyncio.StreamReader(loop=self.loop)
stream.feed_data(self.DATA[:6])
stream.feed_data(self.DATA[6:])
self.assertEqual(len(self.DATA) - len(b'line1\n'), stream._byte_count)
def test_readline_eof(self):
- stream = streams.StreamReader(loop=self.loop)
+ stream = asyncio.StreamReader(loop=self.loop)
stream.feed_data(b'some data')
stream.feed_eof()
self.assertEqual(b'some data', line)
def test_readline_empty_eof(self):
- stream = streams.StreamReader(loop=self.loop)
+ stream = asyncio.StreamReader(loop=self.loop)
stream.feed_eof()
line = self.loop.run_until_complete(stream.readline())
self.assertEqual(b'', line)
def test_readline_read_byte_count(self):
- stream = streams.StreamReader(loop=self.loop)
+ stream = asyncio.StreamReader(loop=self.loop)
stream.feed_data(self.DATA)
self.loop.run_until_complete(stream.readline())
stream._byte_count)
def test_readline_exception(self):
- stream = streams.StreamReader(loop=self.loop)
+ stream = asyncio.StreamReader(loop=self.loop)
stream.feed_data(b'line\n')
data = self.loop.run_until_complete(stream.readline())
def test_readexactly_zero_or_less(self):
# Read exact number of bytes (zero or less).
- stream = streams.StreamReader(loop=self.loop)
+ stream = asyncio.StreamReader(loop=self.loop)
stream.feed_data(self.DATA)
data = self.loop.run_until_complete(stream.readexactly(0))
def test_readexactly(self):
# Read exact number of bytes.
- stream = streams.StreamReader(loop=self.loop)
+ stream = asyncio.StreamReader(loop=self.loop)
n = 2 * len(self.DATA)
- read_task = tasks.Task(stream.readexactly(n), loop=self.loop)
+ read_task = asyncio.Task(stream.readexactly(n), loop=self.loop)
def cb():
stream.feed_data(self.DATA)
def test_readexactly_eof(self):
# Read exact number of bytes (eof).
- stream = streams.StreamReader(loop=self.loop)
+ stream = asyncio.StreamReader(loop=self.loop)
n = 2 * len(self.DATA)
- read_task = tasks.Task(stream.readexactly(n), loop=self.loop)
+ read_task = asyncio.Task(stream.readexactly(n), loop=self.loop)
def cb():
stream.feed_data(self.DATA)
stream.feed_eof()
self.loop.call_soon(cb)
- data = self.loop.run_until_complete(read_task)
- self.assertEqual(self.DATA, data)
+ with self.assertRaises(asyncio.IncompleteReadError) as cm:
+ self.loop.run_until_complete(read_task)
+ self.assertEqual(cm.exception.partial, self.DATA)
+ self.assertEqual(cm.exception.expected, n)
+ self.assertEqual(str(cm.exception),
+ '18 bytes read on a total of 36 expected bytes')
self.assertFalse(stream._byte_count)
def test_readexactly_exception(self):
- stream = streams.StreamReader(loop=self.loop)
+ stream = asyncio.StreamReader(loop=self.loop)
stream.feed_data(b'line\n')
data = self.loop.run_until_complete(stream.readexactly(2))
ValueError, self.loop.run_until_complete, stream.readexactly(2))
def test_exception(self):
- stream = streams.StreamReader(loop=self.loop)
+ stream = asyncio.StreamReader(loop=self.loop)
self.assertIsNone(stream.exception())
exc = ValueError()
self.assertIs(stream.exception(), exc)
def test_exception_waiter(self):
- stream = streams.StreamReader(loop=self.loop)
+ stream = asyncio.StreamReader(loop=self.loop)
- @tasks.coroutine
+ @asyncio.coroutine
def set_err():
stream.set_exception(ValueError())
- @tasks.coroutine
+ @asyncio.coroutine
def readline():
yield from stream.readline()
- t1 = tasks.Task(stream.readline(), loop=self.loop)
- t2 = tasks.Task(set_err(), loop=self.loop)
+ t1 = asyncio.Task(stream.readline(), loop=self.loop)
+ t2 = asyncio.Task(set_err(), loop=self.loop)
- self.loop.run_until_complete(tasks.wait([t1, t2], loop=self.loop))
+ self.loop.run_until_complete(asyncio.wait([t1, t2], loop=self.loop))
self.assertRaises(ValueError, t1.result)
def test_exception_cancel(self):
- stream = streams.StreamReader(loop=self.loop)
+ stream = asyncio.StreamReader(loop=self.loop)
- @tasks.coroutine
+ @asyncio.coroutine
def read_a_line():
yield from stream.readline()
- t = tasks.Task(read_a_line(), loop=self.loop)
+ t = asyncio.Task(read_a_line(), loop=self.loop)
test_utils.run_briefly(self.loop)
t.cancel()
test_utils.run_briefly(self.loop)
self.server = None
self.loop = loop
- @tasks.coroutine
+ @asyncio.coroutine
def handle_client(self, client_reader, client_writer):
data = yield from client_reader.readline()
client_writer.write(data)
def start(self):
self.server = self.loop.run_until_complete(
- streams.start_server(self.handle_client,
+ asyncio.start_server(self.handle_client,
'127.0.0.1', 12345,
loop=self.loop))
def handle_client_callback(self, client_reader, client_writer):
- task = tasks.Task(client_reader.readline(), loop=self.loop)
+ task = asyncio.Task(client_reader.readline(), loop=self.loop)
def done(task):
client_writer.write(task.result())
def start_callback(self):
self.server = self.loop.run_until_complete(
- streams.start_server(self.handle_client_callback,
+ asyncio.start_server(self.handle_client_callback,
'127.0.0.1', 12345,
loop=self.loop))
self.loop.run_until_complete(self.server.wait_closed())
self.server = None
- @tasks.coroutine
+ @asyncio.coroutine
def client():
- reader, writer = yield from streams.open_connection(
+ reader, writer = yield from asyncio.open_connection(
'127.0.0.1', 12345, loop=self.loop)
# send a line
writer.write(b"hello world!\n")
# test the server variant with a coroutine as client handler
server = MyServer(self.loop)
server.start()
- msg = self.loop.run_until_complete(tasks.Task(client(),
+ msg = self.loop.run_until_complete(asyncio.Task(client(),
loop=self.loop))
server.stop()
self.assertEqual(msg, b"hello world!\n")
# test the server variant with a callback as client handler
server = MyServer(self.loop)
server.start_callback()
- msg = self.loop.run_until_complete(tasks.Task(client(),
+ msg = self.loop.run_until_complete(asyncio.Task(client(),
loop=self.loop))
server.stop()
self.assertEqual(msg, b"hello world!\n")
import unittest.mock
from unittest.mock import Mock
-from asyncio import events
-from asyncio import futures
-from asyncio import tasks
+import asyncio
from asyncio import test_utils
def setUp(self):
self.loop = test_utils.TestLoop()
- events.set_event_loop(None)
+ asyncio.set_event_loop(None)
def tearDown(self):
self.loop.close()
gc.collect()
def test_task_class(self):
- @tasks.coroutine
+ @asyncio.coroutine
def notmuch():
return 'ok'
- t = tasks.Task(notmuch(), loop=self.loop)
+ t = asyncio.Task(notmuch(), loop=self.loop)
self.loop.run_until_complete(t)
self.assertTrue(t.done())
self.assertEqual(t.result(), 'ok')
self.assertIs(t._loop, self.loop)
- loop = events.new_event_loop()
- t = tasks.Task(notmuch(), loop=loop)
+ loop = asyncio.new_event_loop()
+ t = asyncio.Task(notmuch(), loop=loop)
self.assertIs(t._loop, loop)
loop.close()
def test_async_coroutine(self):
- @tasks.coroutine
+ @asyncio.coroutine
def notmuch():
return 'ok'
- t = tasks.async(notmuch(), loop=self.loop)
+ t = asyncio.async(notmuch(), loop=self.loop)
self.loop.run_until_complete(t)
self.assertTrue(t.done())
self.assertEqual(t.result(), 'ok')
self.assertIs(t._loop, self.loop)
- loop = events.new_event_loop()
- t = tasks.async(notmuch(), loop=loop)
+ loop = asyncio.new_event_loop()
+ t = asyncio.async(notmuch(), loop=loop)
self.assertIs(t._loop, loop)
loop.close()
def test_async_future(self):
- f_orig = futures.Future(loop=self.loop)
+ f_orig = asyncio.Future(loop=self.loop)
f_orig.set_result('ko')
- f = tasks.async(f_orig)
+ f = asyncio.async(f_orig)
self.loop.run_until_complete(f)
self.assertTrue(f.done())
self.assertEqual(f.result(), 'ko')
self.assertIs(f, f_orig)
- loop = events.new_event_loop()
+ loop = asyncio.new_event_loop()
with self.assertRaises(ValueError):
- f = tasks.async(f_orig, loop=loop)
+ f = asyncio.async(f_orig, loop=loop)
loop.close()
- f = tasks.async(f_orig, loop=self.loop)
+ f = asyncio.async(f_orig, loop=self.loop)
self.assertIs(f, f_orig)
def test_async_task(self):
- @tasks.coroutine
+ @asyncio.coroutine
def notmuch():
return 'ok'
- t_orig = tasks.Task(notmuch(), loop=self.loop)
- t = tasks.async(t_orig)
+ t_orig = asyncio.Task(notmuch(), loop=self.loop)
+ t = asyncio.async(t_orig)
self.loop.run_until_complete(t)
self.assertTrue(t.done())
self.assertEqual(t.result(), 'ok')
self.assertIs(t, t_orig)
- loop = events.new_event_loop()
+ loop = asyncio.new_event_loop()
with self.assertRaises(ValueError):
- t = tasks.async(t_orig, loop=loop)
+ t = asyncio.async(t_orig, loop=loop)
loop.close()
- t = tasks.async(t_orig, loop=self.loop)
+ t = asyncio.async(t_orig, loop=self.loop)
self.assertIs(t, t_orig)
def test_async_neither(self):
with self.assertRaises(TypeError):
- tasks.async('ok')
+ asyncio.async('ok')
def test_task_repr(self):
- @tasks.coroutine
+ @asyncio.coroutine
def notmuch():
yield from []
return 'abc'
- t = tasks.Task(notmuch(), loop=self.loop)
+ t = asyncio.Task(notmuch(), loop=self.loop)
t.add_done_callback(Dummy())
self.assertEqual(repr(t), 'Task(<notmuch>)<PENDING, [Dummy()]>')
t.cancel() # Does not take immediate effect!
self.assertEqual(repr(t), 'Task(<notmuch>)<CANCELLING, [Dummy()]>')
- self.assertRaises(futures.CancelledError,
+ self.assertRaises(asyncio.CancelledError,
self.loop.run_until_complete, t)
self.assertEqual(repr(t), 'Task(<notmuch>)<CANCELLED>')
- t = tasks.Task(notmuch(), loop=self.loop)
+ t = asyncio.Task(notmuch(), loop=self.loop)
self.loop.run_until_complete(t)
self.assertEqual(repr(t), "Task(<notmuch>)<result='abc'>")
def test_task_repr_custom(self):
- @tasks.coroutine
+ @asyncio.coroutine
def coro():
pass
- class T(futures.Future):
+ class T(asyncio.Future):
def __repr__(self):
return 'T[]'
- class MyTask(tasks.Task, T):
+ class MyTask(asyncio.Task, T):
def __repr__(self):
return super().__repr__()
gen.close()
def test_task_basics(self):
- @tasks.coroutine
+ @asyncio.coroutine
def outer():
a = yield from inner1()
b = yield from inner2()
return a+b
- @tasks.coroutine
+ @asyncio.coroutine
def inner1():
return 42
- @tasks.coroutine
+ @asyncio.coroutine
def inner2():
return 1000
loop = test_utils.TestLoop(gen)
self.addCleanup(loop.close)
- @tasks.coroutine
+ @asyncio.coroutine
def task():
- yield from tasks.sleep(10.0, loop=loop)
+ yield from asyncio.sleep(10.0, loop=loop)
return 12
- t = tasks.Task(task(), loop=loop)
+ t = asyncio.Task(task(), loop=loop)
loop.call_soon(t.cancel)
- with self.assertRaises(futures.CancelledError):
+ with self.assertRaises(asyncio.CancelledError):
loop.run_until_complete(t)
self.assertTrue(t.done())
self.assertTrue(t.cancelled())
self.assertFalse(t.cancel())
def test_cancel_yield(self):
- @tasks.coroutine
+ @asyncio.coroutine
def task():
yield
yield
return 12
- t = tasks.Task(task(), loop=self.loop)
+ t = asyncio.Task(task(), loop=self.loop)
test_utils.run_briefly(self.loop) # start coro
t.cancel()
self.assertRaises(
- futures.CancelledError, self.loop.run_until_complete, t)
+ asyncio.CancelledError, self.loop.run_until_complete, t)
self.assertTrue(t.done())
self.assertTrue(t.cancelled())
self.assertFalse(t.cancel())
def test_cancel_inner_future(self):
- f = futures.Future(loop=self.loop)
+ f = asyncio.Future(loop=self.loop)
- @tasks.coroutine
+ @asyncio.coroutine
def task():
yield from f
return 12
- t = tasks.Task(task(), loop=self.loop)
+ t = asyncio.Task(task(), loop=self.loop)
test_utils.run_briefly(self.loop) # start task
f.cancel()
- with self.assertRaises(futures.CancelledError):
+ with self.assertRaises(asyncio.CancelledError):
self.loop.run_until_complete(t)
self.assertTrue(f.cancelled())
self.assertTrue(t.cancelled())
def test_cancel_both_task_and_inner_future(self):
- f = futures.Future(loop=self.loop)
+ f = asyncio.Future(loop=self.loop)
- @tasks.coroutine
+ @asyncio.coroutine
def task():
yield from f
return 12
- t = tasks.Task(task(), loop=self.loop)
+ t = asyncio.Task(task(), loop=self.loop)
test_utils.run_briefly(self.loop)
f.cancel()
t.cancel()
- with self.assertRaises(futures.CancelledError):
+ with self.assertRaises(asyncio.CancelledError):
self.loop.run_until_complete(t)
self.assertTrue(t.done())
self.assertTrue(t.cancelled())
def test_cancel_task_catching(self):
- fut1 = futures.Future(loop=self.loop)
- fut2 = futures.Future(loop=self.loop)
+ fut1 = asyncio.Future(loop=self.loop)
+ fut2 = asyncio.Future(loop=self.loop)
- @tasks.coroutine
+ @asyncio.coroutine
def task():
yield from fut1
try:
yield from fut2
- except futures.CancelledError:
+ except asyncio.CancelledError:
return 42
- t = tasks.Task(task(), loop=self.loop)
+ t = asyncio.Task(task(), loop=self.loop)
test_utils.run_briefly(self.loop)
self.assertIs(t._fut_waiter, fut1) # White-box test.
fut1.set_result(None)
self.assertFalse(t.cancelled())
def test_cancel_task_ignoring(self):
- fut1 = futures.Future(loop=self.loop)
- fut2 = futures.Future(loop=self.loop)
- fut3 = futures.Future(loop=self.loop)
+ fut1 = asyncio.Future(loop=self.loop)
+ fut2 = asyncio.Future(loop=self.loop)
+ fut3 = asyncio.Future(loop=self.loop)
- @tasks.coroutine
+ @asyncio.coroutine
def task():
yield from fut1
try:
yield from fut2
- except futures.CancelledError:
+ except asyncio.CancelledError:
pass
res = yield from fut3
return res
- t = tasks.Task(task(), loop=self.loop)
+ t = asyncio.Task(task(), loop=self.loop)
test_utils.run_briefly(self.loop)
self.assertIs(t._fut_waiter, fut1) # White-box test.
fut1.set_result(None)
self.assertFalse(t.cancelled())
def test_cancel_current_task(self):
- loop = events.new_event_loop()
+ loop = asyncio.new_event_loop()
self.addCleanup(loop.close)
- @tasks.coroutine
+ @asyncio.coroutine
def task():
t.cancel()
self.assertTrue(t._must_cancel) # White-box test.
# The sleep should be cancelled immediately.
- yield from tasks.sleep(100, loop=loop)
+ yield from asyncio.sleep(100, loop=loop)
return 12
- t = tasks.Task(task(), loop=loop)
+ t = asyncio.Task(task(), loop=loop)
self.assertRaises(
- futures.CancelledError, loop.run_until_complete, t)
+ asyncio.CancelledError, loop.run_until_complete, t)
self.assertTrue(t.done())
self.assertFalse(t._must_cancel) # White-box test.
self.assertFalse(t.cancel())
x = 0
waiters = []
- @tasks.coroutine
+ @asyncio.coroutine
def task():
nonlocal x
while x < 10:
- waiters.append(tasks.sleep(0.1, loop=loop))
+ waiters.append(asyncio.sleep(0.1, loop=loop))
yield from waiters[-1]
x += 1
if x == 2:
loop.stop()
- t = tasks.Task(task(), loop=loop)
+ t = asyncio.Task(task(), loop=loop)
self.assertRaises(
RuntimeError, loop.run_until_complete, t)
self.assertFalse(t.done())
foo_running = None
- @tasks.coroutine
+ @asyncio.coroutine
def foo():
nonlocal foo_running
foo_running = True
try:
- yield from tasks.sleep(0.2, loop=loop)
+ yield from asyncio.sleep(0.2, loop=loop)
finally:
foo_running = False
return 'done'
- fut = tasks.Task(foo(), loop=loop)
+ fut = asyncio.Task(foo(), loop=loop)
- with self.assertRaises(futures.TimeoutError):
- loop.run_until_complete(tasks.wait_for(fut, 0.1, loop=loop))
+ with self.assertRaises(asyncio.TimeoutError):
+ loop.run_until_complete(asyncio.wait_for(fut, 0.1, loop=loop))
self.assertTrue(fut.done())
# it should have been cancelled due to the timeout
self.assertTrue(fut.cancelled())
loop = test_utils.TestLoop(gen)
self.addCleanup(loop.close)
- @tasks.coroutine
+ @asyncio.coroutine
def foo():
- yield from tasks.sleep(0.2, loop=loop)
+ yield from asyncio.sleep(0.2, loop=loop)
return 'done'
- events.set_event_loop(loop)
+ asyncio.set_event_loop(loop)
try:
- fut = tasks.Task(foo(), loop=loop)
- with self.assertRaises(futures.TimeoutError):
- loop.run_until_complete(tasks.wait_for(fut, 0.01))
+ fut = asyncio.Task(foo(), loop=loop)
+ with self.assertRaises(asyncio.TimeoutError):
+ loop.run_until_complete(asyncio.wait_for(fut, 0.01))
finally:
- events.set_event_loop(None)
+ asyncio.set_event_loop(None)
self.assertAlmostEqual(0.01, loop.time())
self.assertTrue(fut.done())
loop = test_utils.TestLoop(gen)
self.addCleanup(loop.close)
- a = tasks.Task(tasks.sleep(0.1, loop=loop), loop=loop)
- b = tasks.Task(tasks.sleep(0.15, loop=loop), loop=loop)
+ a = asyncio.Task(asyncio.sleep(0.1, loop=loop), loop=loop)
+ b = asyncio.Task(asyncio.sleep(0.15, loop=loop), loop=loop)
- @tasks.coroutine
+ @asyncio.coroutine
def foo():
- done, pending = yield from tasks.wait([b, a], loop=loop)
+ done, pending = yield from asyncio.wait([b, a], loop=loop)
self.assertEqual(done, set([a, b]))
self.assertEqual(pending, set())
return 42
- res = loop.run_until_complete(tasks.Task(foo(), loop=loop))
+ res = loop.run_until_complete(asyncio.Task(foo(), loop=loop))
self.assertEqual(res, 42)
self.assertAlmostEqual(0.15, loop.time())
# Doing it again should take no time and exercise a different path.
- res = loop.run_until_complete(tasks.Task(foo(), loop=loop))
+ res = loop.run_until_complete(asyncio.Task(foo(), loop=loop))
self.assertAlmostEqual(0.15, loop.time())
self.assertEqual(res, 42)
loop = test_utils.TestLoop(gen)
self.addCleanup(loop.close)
- a = tasks.Task(tasks.sleep(0.01, loop=loop), loop=loop)
- b = tasks.Task(tasks.sleep(0.015, loop=loop), loop=loop)
+ a = asyncio.Task(asyncio.sleep(0.01, loop=loop), loop=loop)
+ b = asyncio.Task(asyncio.sleep(0.015, loop=loop), loop=loop)
- @tasks.coroutine
+ @asyncio.coroutine
def foo():
- done, pending = yield from tasks.wait([b, a])
+ done, pending = yield from asyncio.wait([b, a])
self.assertEqual(done, set([a, b]))
self.assertEqual(pending, set())
return 42
- events.set_event_loop(loop)
+ asyncio.set_event_loop(loop)
try:
res = loop.run_until_complete(
- tasks.Task(foo(), loop=loop))
+ asyncio.Task(foo(), loop=loop))
finally:
- events.set_event_loop(None)
+ asyncio.set_event_loop(None)
self.assertEqual(res, 42)
def test_wait_errors(self):
self.assertRaises(
ValueError, self.loop.run_until_complete,
- tasks.wait(set(), loop=self.loop))
+ asyncio.wait(set(), loop=self.loop))
self.assertRaises(
ValueError, self.loop.run_until_complete,
- tasks.wait([tasks.sleep(10.0, loop=self.loop)],
+ asyncio.wait([asyncio.sleep(10.0, loop=self.loop)],
return_when=-1, loop=self.loop))
def test_wait_first_completed(self):
loop = test_utils.TestLoop(gen)
self.addCleanup(loop.close)
- a = tasks.Task(tasks.sleep(10.0, loop=loop), loop=loop)
- b = tasks.Task(tasks.sleep(0.1, loop=loop), loop=loop)
- task = tasks.Task(
- tasks.wait([b, a], return_when=tasks.FIRST_COMPLETED,
+ a = asyncio.Task(asyncio.sleep(10.0, loop=loop), loop=loop)
+ b = asyncio.Task(asyncio.sleep(0.1, loop=loop), loop=loop)
+ task = asyncio.Task(
+ asyncio.wait([b, a], return_when=asyncio.FIRST_COMPLETED,
loop=loop),
loop=loop)
# move forward to close generator
loop.advance_time(10)
- loop.run_until_complete(tasks.wait([a, b], loop=loop))
+ loop.run_until_complete(asyncio.wait([a, b], loop=loop))
def test_wait_really_done(self):
# there is possibility that some tasks in the pending list
# became done but their callbacks haven't all been called yet
- @tasks.coroutine
+ @asyncio.coroutine
def coro1():
yield
- @tasks.coroutine
+ @asyncio.coroutine
def coro2():
yield
yield
- a = tasks.Task(coro1(), loop=self.loop)
- b = tasks.Task(coro2(), loop=self.loop)
- task = tasks.Task(
- tasks.wait([b, a], return_when=tasks.FIRST_COMPLETED,
+ a = asyncio.Task(coro1(), loop=self.loop)
+ b = asyncio.Task(coro2(), loop=self.loop)
+ task = asyncio.Task(
+ asyncio.wait([b, a], return_when=asyncio.FIRST_COMPLETED,
loop=self.loop),
loop=self.loop)
self.addCleanup(loop.close)
# first_exception, task already has exception
- a = tasks.Task(tasks.sleep(10.0, loop=loop), loop=loop)
+ a = asyncio.Task(asyncio.sleep(10.0, loop=loop), loop=loop)
- @tasks.coroutine
+ @asyncio.coroutine
def exc():
raise ZeroDivisionError('err')
- b = tasks.Task(exc(), loop=loop)
- task = tasks.Task(
- tasks.wait([b, a], return_when=tasks.FIRST_EXCEPTION,
+ b = asyncio.Task(exc(), loop=loop)
+ task = asyncio.Task(
+ asyncio.wait([b, a], return_when=asyncio.FIRST_EXCEPTION,
loop=loop),
loop=loop)
# move forward to close generator
loop.advance_time(10)
- loop.run_until_complete(tasks.wait([a, b], loop=loop))
+ loop.run_until_complete(asyncio.wait([a, b], loop=loop))
def test_wait_first_exception_in_wait(self):
self.addCleanup(loop.close)
# first_exception, exception during waiting
- a = tasks.Task(tasks.sleep(10.0, loop=loop), loop=loop)
+ a = asyncio.Task(asyncio.sleep(10.0, loop=loop), loop=loop)
- @tasks.coroutine
+ @asyncio.coroutine
def exc():
- yield from tasks.sleep(0.01, loop=loop)
+ yield from asyncio.sleep(0.01, loop=loop)
raise ZeroDivisionError('err')
- b = tasks.Task(exc(), loop=loop)
- task = tasks.wait([b, a], return_when=tasks.FIRST_EXCEPTION,
+ b = asyncio.Task(exc(), loop=loop)
+ task = asyncio.wait([b, a], return_when=asyncio.FIRST_EXCEPTION,
loop=loop)
done, pending = loop.run_until_complete(task)
# move forward to close generator
loop.advance_time(10)
- loop.run_until_complete(tasks.wait([a, b], loop=loop))
+ loop.run_until_complete(asyncio.wait([a, b], loop=loop))
def test_wait_with_exception(self):
loop = test_utils.TestLoop(gen)
self.addCleanup(loop.close)
- a = tasks.Task(tasks.sleep(0.1, loop=loop), loop=loop)
+ a = asyncio.Task(asyncio.sleep(0.1, loop=loop), loop=loop)
- @tasks.coroutine
+ @asyncio.coroutine
def sleeper():
- yield from tasks.sleep(0.15, loop=loop)
+ yield from asyncio.sleep(0.15, loop=loop)
raise ZeroDivisionError('really')
- b = tasks.Task(sleeper(), loop=loop)
+ b = asyncio.Task(sleeper(), loop=loop)
- @tasks.coroutine
+ @asyncio.coroutine
def foo():
- done, pending = yield from tasks.wait([b, a], loop=loop)
+ done, pending = yield from asyncio.wait([b, a], loop=loop)
self.assertEqual(len(done), 2)
self.assertEqual(pending, set())
errors = set(f for f in done if f.exception() is not None)
self.assertEqual(len(errors), 1)
- loop.run_until_complete(tasks.Task(foo(), loop=loop))
+ loop.run_until_complete(asyncio.Task(foo(), loop=loop))
self.assertAlmostEqual(0.15, loop.time())
- loop.run_until_complete(tasks.Task(foo(), loop=loop))
+ loop.run_until_complete(asyncio.Task(foo(), loop=loop))
self.assertAlmostEqual(0.15, loop.time())
def test_wait_with_timeout(self):
loop = test_utils.TestLoop(gen)
self.addCleanup(loop.close)
- a = tasks.Task(tasks.sleep(0.1, loop=loop), loop=loop)
- b = tasks.Task(tasks.sleep(0.15, loop=loop), loop=loop)
+ a = asyncio.Task(asyncio.sleep(0.1, loop=loop), loop=loop)
+ b = asyncio.Task(asyncio.sleep(0.15, loop=loop), loop=loop)
- @tasks.coroutine
+ @asyncio.coroutine
def foo():
- done, pending = yield from tasks.wait([b, a], timeout=0.11,
+ done, pending = yield from asyncio.wait([b, a], timeout=0.11,
loop=loop)
self.assertEqual(done, set([a]))
self.assertEqual(pending, set([b]))
- loop.run_until_complete(tasks.Task(foo(), loop=loop))
+ loop.run_until_complete(asyncio.Task(foo(), loop=loop))
self.assertAlmostEqual(0.11, loop.time())
# move forward to close generator
loop.advance_time(10)
- loop.run_until_complete(tasks.wait([a, b], loop=loop))
+ loop.run_until_complete(asyncio.wait([a, b], loop=loop))
def test_wait_concurrent_complete(self):
loop = test_utils.TestLoop(gen)
self.addCleanup(loop.close)
- a = tasks.Task(tasks.sleep(0.1, loop=loop), loop=loop)
- b = tasks.Task(tasks.sleep(0.15, loop=loop), loop=loop)
+ a = asyncio.Task(asyncio.sleep(0.1, loop=loop), loop=loop)
+ b = asyncio.Task(asyncio.sleep(0.15, loop=loop), loop=loop)
done, pending = loop.run_until_complete(
- tasks.wait([b, a], timeout=0.1, loop=loop))
+ asyncio.wait([b, a], timeout=0.1, loop=loop))
self.assertEqual(done, set([a]))
self.assertEqual(pending, set([b]))
# move forward to close generator
loop.advance_time(10)
- loop.run_until_complete(tasks.wait([a, b], loop=loop))
+ loop.run_until_complete(asyncio.wait([a, b], loop=loop))
def test_as_completed(self):
completed = set()
time_shifted = False
- @tasks.coroutine
+ @asyncio.coroutine
def sleeper(dt, x):
nonlocal time_shifted
- yield from tasks.sleep(dt, loop=loop)
+ yield from asyncio.sleep(dt, loop=loop)
completed.add(x)
if not time_shifted and 'a' in completed and 'b' in completed:
time_shifted = True
b = sleeper(0.01, 'b')
c = sleeper(0.15, 'c')
- @tasks.coroutine
+ @asyncio.coroutine
def foo():
values = []
- for f in tasks.as_completed([b, c, a], loop=loop):
+ for f in asyncio.as_completed([b, c, a], loop=loop):
values.append((yield from f))
return values
- res = loop.run_until_complete(tasks.Task(foo(), loop=loop))
+ res = loop.run_until_complete(asyncio.Task(foo(), loop=loop))
self.assertAlmostEqual(0.15, loop.time())
self.assertTrue('a' in res[:2])
self.assertTrue('b' in res[:2])
self.assertEqual(res[2], 'c')
# Doing it again should take no time and exercise a different path.
- res = loop.run_until_complete(tasks.Task(foo(), loop=loop))
+ res = loop.run_until_complete(asyncio.Task(foo(), loop=loop))
self.assertAlmostEqual(0.15, loop.time())
def test_as_completed_with_timeout(self):
loop = test_utils.TestLoop(gen)
self.addCleanup(loop.close)
- a = tasks.sleep(0.1, 'a', loop=loop)
- b = tasks.sleep(0.15, 'b', loop=loop)
+ a = asyncio.sleep(0.1, 'a', loop=loop)
+ b = asyncio.sleep(0.15, 'b', loop=loop)
- @tasks.coroutine
+ @asyncio.coroutine
def foo():
values = []
- for f in tasks.as_completed([a, b], timeout=0.12, loop=loop):
+ for f in asyncio.as_completed([a, b], timeout=0.12, loop=loop):
try:
v = yield from f
values.append((1, v))
- except futures.TimeoutError as exc:
+ except asyncio.TimeoutError as exc:
values.append((2, exc))
return values
- res = loop.run_until_complete(tasks.Task(foo(), loop=loop))
+ res = loop.run_until_complete(asyncio.Task(foo(), loop=loop))
self.assertEqual(len(res), 2, res)
self.assertEqual(res[0], (1, 'a'))
self.assertEqual(res[1][0], 2)
- self.assertIsInstance(res[1][1], futures.TimeoutError)
+ self.assertIsInstance(res[1][1], asyncio.TimeoutError)
self.assertAlmostEqual(0.12, loop.time())
# move forward to close generator
loop.advance_time(10)
- loop.run_until_complete(tasks.wait([a, b], loop=loop))
+ loop.run_until_complete(asyncio.wait([a, b], loop=loop))
def test_as_completed_reverse_wait(self):
loop = test_utils.TestLoop(gen)
self.addCleanup(loop.close)
- a = tasks.sleep(0.05, 'a', loop=loop)
- b = tasks.sleep(0.10, 'b', loop=loop)
+ a = asyncio.sleep(0.05, 'a', loop=loop)
+ b = asyncio.sleep(0.10, 'b', loop=loop)
fs = {a, b}
- futs = list(tasks.as_completed(fs, loop=loop))
+ futs = list(asyncio.as_completed(fs, loop=loop))
self.assertEqual(len(futs), 2)
x = loop.run_until_complete(futs[1])
loop = test_utils.TestLoop(gen)
self.addCleanup(loop.close)
- a = tasks.sleep(0.05, 'a', loop=loop)
- b = tasks.sleep(0.05, 'b', loop=loop)
+ a = asyncio.sleep(0.05, 'a', loop=loop)
+ b = asyncio.sleep(0.05, 'b', loop=loop)
fs = {a, b}
- futs = list(tasks.as_completed(fs, loop=loop))
+ futs = list(asyncio.as_completed(fs, loop=loop))
self.assertEqual(len(futs), 2)
- waiter = tasks.wait(futs, loop=loop)
+ waiter = asyncio.wait(futs, loop=loop)
done, pending = loop.run_until_complete(waiter)
self.assertEqual(set(f.result() for f in done), {'a', 'b'})
loop = test_utils.TestLoop(gen)
self.addCleanup(loop.close)
- @tasks.coroutine
+ @asyncio.coroutine
def sleeper(dt, arg):
- yield from tasks.sleep(dt/2, loop=loop)
- res = yield from tasks.sleep(dt/2, arg, loop=loop)
+ yield from asyncio.sleep(dt/2, loop=loop)
+ res = yield from asyncio.sleep(dt/2, arg, loop=loop)
return res
- t = tasks.Task(sleeper(0.1, 'yeah'), loop=loop)
+ t = asyncio.Task(sleeper(0.1, 'yeah'), loop=loop)
loop.run_until_complete(t)
self.assertTrue(t.done())
self.assertEqual(t.result(), 'yeah')
loop = test_utils.TestLoop(gen)
self.addCleanup(loop.close)
- t = tasks.Task(tasks.sleep(10.0, 'yeah', loop=loop),
+ t = asyncio.Task(asyncio.sleep(10.0, 'yeah', loop=loop),
loop=loop)
handle = None
sleepfut = None
- @tasks.coroutine
+ @asyncio.coroutine
def sleep(dt):
nonlocal sleepfut
- sleepfut = tasks.sleep(dt, loop=loop)
+ sleepfut = asyncio.sleep(dt, loop=loop)
yield from sleepfut
- @tasks.coroutine
+ @asyncio.coroutine
def doit():
- sleeper = tasks.Task(sleep(5000), loop=loop)
+ sleeper = asyncio.Task(sleep(5000), loop=loop)
loop.call_later(0.1, sleeper.cancel)
try:
yield from sleeper
- except futures.CancelledError:
+ except asyncio.CancelledError:
return 'cancelled'
else:
return 'slept in'
self.assertAlmostEqual(0.1, loop.time())
def test_task_cancel_waiter_future(self):
- fut = futures.Future(loop=self.loop)
+ fut = asyncio.Future(loop=self.loop)
- @tasks.coroutine
+ @asyncio.coroutine
def coro():
yield from fut
- task = tasks.Task(coro(), loop=self.loop)
+ task = asyncio.Task(coro(), loop=self.loop)
test_utils.run_briefly(self.loop)
self.assertIs(task._fut_waiter, fut)
task.cancel()
test_utils.run_briefly(self.loop)
self.assertRaises(
- futures.CancelledError, self.loop.run_until_complete, task)
+ asyncio.CancelledError, self.loop.run_until_complete, task)
self.assertIsNone(task._fut_waiter)
self.assertTrue(fut.cancelled())
def test_step_in_completed_task(self):
- @tasks.coroutine
+ @asyncio.coroutine
def notmuch():
return 'ko'
gen = notmuch()
- task = tasks.Task(gen, loop=self.loop)
+ task = asyncio.Task(gen, loop=self.loop)
task.set_result('ok')
self.assertRaises(AssertionError, task._step)
gen.close()
def test_step_result(self):
- @tasks.coroutine
+ @asyncio.coroutine
def notmuch():
yield None
yield 1
def test_step_result_future(self):
# If coroutine returns future, task waits on this future.
- class Fut(futures.Future):
+ class Fut(asyncio.Future):
def __init__(self, *args, **kwds):
self.cb_added = False
super().__init__(*args, **kwds)
fut = Fut(loop=self.loop)
result = None
- @tasks.coroutine
+ @asyncio.coroutine
def wait_for_future():
nonlocal result
result = yield from fut
- t = tasks.Task(wait_for_future(), loop=self.loop)
+ t = asyncio.Task(wait_for_future(), loop=self.loop)
test_utils.run_briefly(self.loop)
self.assertTrue(fut.cb_added)
self.assertIsNone(t.result())
def test_step_with_baseexception(self):
- @tasks.coroutine
+ @asyncio.coroutine
def notmutch():
raise BaseException()
- task = tasks.Task(notmutch(), loop=self.loop)
+ task = asyncio.Task(notmutch(), loop=self.loop)
self.assertRaises(BaseException, task._step)
self.assertTrue(task.done())
loop = test_utils.TestLoop(gen)
self.addCleanup(loop.close)
- @tasks.coroutine
+ @asyncio.coroutine
def sleeper():
- yield from tasks.sleep(10, loop=loop)
+ yield from asyncio.sleep(10, loop=loop)
base_exc = BaseException()
- @tasks.coroutine
+ @asyncio.coroutine
def notmutch():
try:
yield from sleeper()
- except futures.CancelledError:
+ except asyncio.CancelledError:
raise base_exc
- task = tasks.Task(notmutch(), loop=loop)
+ task = asyncio.Task(notmutch(), loop=loop)
test_utils.run_briefly(loop)
task.cancel()
def fn():
pass
- self.assertFalse(tasks.iscoroutinefunction(fn))
+ self.assertFalse(asyncio.iscoroutinefunction(fn))
def fn1():
yield
- self.assertFalse(tasks.iscoroutinefunction(fn1))
+ self.assertFalse(asyncio.iscoroutinefunction(fn1))
- @tasks.coroutine
+ @asyncio.coroutine
def fn2():
yield
- self.assertTrue(tasks.iscoroutinefunction(fn2))
+ self.assertTrue(asyncio.iscoroutinefunction(fn2))
def test_yield_vs_yield_from(self):
- fut = futures.Future(loop=self.loop)
+ fut = asyncio.Future(loop=self.loop)
- @tasks.coroutine
+ @asyncio.coroutine
def wait_for_future():
yield fut
self.assertFalse(fut.done())
def test_yield_vs_yield_from_generator(self):
- @tasks.coroutine
+ @asyncio.coroutine
def coro():
yield
- @tasks.coroutine
+ @asyncio.coroutine
def wait_for_future():
gen = coro()
try:
self.loop.run_until_complete, task)
def test_coroutine_non_gen_function(self):
- @tasks.coroutine
+ @asyncio.coroutine
def func():
return 'test'
- self.assertTrue(tasks.iscoroutinefunction(func))
+ self.assertTrue(asyncio.iscoroutinefunction(func))
coro = func()
- self.assertTrue(tasks.iscoroutine(coro))
+ self.assertTrue(asyncio.iscoroutine(coro))
res = self.loop.run_until_complete(coro)
self.assertEqual(res, 'test')
def test_coroutine_non_gen_function_return_future(self):
- fut = futures.Future(loop=self.loop)
+ fut = asyncio.Future(loop=self.loop)
- @tasks.coroutine
+ @asyncio.coroutine
def func():
return fut
- @tasks.coroutine
+ @asyncio.coroutine
def coro():
fut.set_result('test')
- t1 = tasks.Task(func(), loop=self.loop)
- t2 = tasks.Task(coro(), loop=self.loop)
+ t1 = asyncio.Task(func(), loop=self.loop)
+ t2 = asyncio.Task(coro(), loop=self.loop)
res = self.loop.run_until_complete(t1)
self.assertEqual(res, 'test')
self.assertIsNone(t2.result())
def test_current_task(self):
- self.assertIsNone(tasks.Task.current_task(loop=self.loop))
+ self.assertIsNone(asyncio.Task.current_task(loop=self.loop))
- @tasks.coroutine
+ @asyncio.coroutine
def coro(loop):
- self.assertTrue(tasks.Task.current_task(loop=loop) is task)
+ self.assertTrue(asyncio.Task.current_task(loop=loop) is task)
- task = tasks.Task(coro(self.loop), loop=self.loop)
+ task = asyncio.Task(coro(self.loop), loop=self.loop)
self.loop.run_until_complete(task)
- self.assertIsNone(tasks.Task.current_task(loop=self.loop))
+ self.assertIsNone(asyncio.Task.current_task(loop=self.loop))
def test_current_task_with_interleaving_tasks(self):
- self.assertIsNone(tasks.Task.current_task(loop=self.loop))
+ self.assertIsNone(asyncio.Task.current_task(loop=self.loop))
- fut1 = futures.Future(loop=self.loop)
- fut2 = futures.Future(loop=self.loop)
+ fut1 = asyncio.Future(loop=self.loop)
+ fut2 = asyncio.Future(loop=self.loop)
- @tasks.coroutine
+ @asyncio.coroutine
def coro1(loop):
- self.assertTrue(tasks.Task.current_task(loop=loop) is task1)
+ self.assertTrue(asyncio.Task.current_task(loop=loop) is task1)
yield from fut1
- self.assertTrue(tasks.Task.current_task(loop=loop) is task1)
+ self.assertTrue(asyncio.Task.current_task(loop=loop) is task1)
fut2.set_result(True)
- @tasks.coroutine
+ @asyncio.coroutine
def coro2(loop):
- self.assertTrue(tasks.Task.current_task(loop=loop) is task2)
+ self.assertTrue(asyncio.Task.current_task(loop=loop) is task2)
fut1.set_result(True)
yield from fut2
- self.assertTrue(tasks.Task.current_task(loop=loop) is task2)
+ self.assertTrue(asyncio.Task.current_task(loop=loop) is task2)
- task1 = tasks.Task(coro1(self.loop), loop=self.loop)
- task2 = tasks.Task(coro2(self.loop), loop=self.loop)
+ task1 = asyncio.Task(coro1(self.loop), loop=self.loop)
+ task2 = asyncio.Task(coro2(self.loop), loop=self.loop)
- self.loop.run_until_complete(tasks.wait((task1, task2),
+ self.loop.run_until_complete(asyncio.wait((task1, task2),
loop=self.loop))
- self.assertIsNone(tasks.Task.current_task(loop=self.loop))
+ self.assertIsNone(asyncio.Task.current_task(loop=self.loop))
# Some thorough tests for cancellation propagation through
# coroutines, tasks and wait().
def test_yield_future_passes_cancel(self):
# Cancelling outer() cancels inner() cancels waiter.
proof = 0
- waiter = futures.Future(loop=self.loop)
+ waiter = asyncio.Future(loop=self.loop)
- @tasks.coroutine
+ @asyncio.coroutine
def inner():
nonlocal proof
try:
yield from waiter
- except futures.CancelledError:
+ except asyncio.CancelledError:
proof += 1
raise
else:
self.fail('got past sleep() in inner()')
- @tasks.coroutine
+ @asyncio.coroutine
def outer():
nonlocal proof
try:
yield from inner()
- except futures.CancelledError:
+ except asyncio.CancelledError:
proof += 100 # Expect this path.
else:
proof += 10
- f = tasks.async(outer(), loop=self.loop)
+ f = asyncio.async(outer(), loop=self.loop)
test_utils.run_briefly(self.loop)
f.cancel()
self.loop.run_until_complete(f)
# Cancelling outer() makes wait() return early, leaves inner()
# running.
proof = 0
- waiter = futures.Future(loop=self.loop)
+ waiter = asyncio.Future(loop=self.loop)
- @tasks.coroutine
+ @asyncio.coroutine
def inner():
nonlocal proof
yield from waiter
proof += 1
- @tasks.coroutine
+ @asyncio.coroutine
def outer():
nonlocal proof
- d, p = yield from tasks.wait([inner()], loop=self.loop)
+ d, p = yield from asyncio.wait([inner()], loop=self.loop)
proof += 100
- f = tasks.async(outer(), loop=self.loop)
+ f = asyncio.async(outer(), loop=self.loop)
test_utils.run_briefly(self.loop)
f.cancel()
self.assertRaises(
- futures.CancelledError, self.loop.run_until_complete, f)
+ asyncio.CancelledError, self.loop.run_until_complete, f)
waiter.set_result(None)
test_utils.run_briefly(self.loop)
self.assertEqual(proof, 1)
def test_shield_result(self):
- inner = futures.Future(loop=self.loop)
- outer = tasks.shield(inner)
+ inner = asyncio.Future(loop=self.loop)
+ outer = asyncio.shield(inner)
inner.set_result(42)
res = self.loop.run_until_complete(outer)
self.assertEqual(res, 42)
def test_shield_exception(self):
- inner = futures.Future(loop=self.loop)
- outer = tasks.shield(inner)
+ inner = asyncio.Future(loop=self.loop)
+ outer = asyncio.shield(inner)
test_utils.run_briefly(self.loop)
exc = RuntimeError('expected')
inner.set_exception(exc)
self.assertIs(outer.exception(), exc)
def test_shield_cancel(self):
- inner = futures.Future(loop=self.loop)
- outer = tasks.shield(inner)
+ inner = asyncio.Future(loop=self.loop)
+ outer = asyncio.shield(inner)
test_utils.run_briefly(self.loop)
inner.cancel()
test_utils.run_briefly(self.loop)
self.assertTrue(outer.cancelled())
def test_shield_shortcut(self):
- fut = futures.Future(loop=self.loop)
+ fut = asyncio.Future(loop=self.loop)
fut.set_result(42)
- res = self.loop.run_until_complete(tasks.shield(fut))
+ res = self.loop.run_until_complete(asyncio.shield(fut))
self.assertEqual(res, 42)
def test_shield_effect(self):
# Cancelling outer() does not affect inner().
proof = 0
- waiter = futures.Future(loop=self.loop)
+ waiter = asyncio.Future(loop=self.loop)
- @tasks.coroutine
+ @asyncio.coroutine
def inner():
nonlocal proof
yield from waiter
proof += 1
- @tasks.coroutine
+ @asyncio.coroutine
def outer():
nonlocal proof
- yield from tasks.shield(inner(), loop=self.loop)
+ yield from asyncio.shield(inner(), loop=self.loop)
proof += 100
- f = tasks.async(outer(), loop=self.loop)
+ f = asyncio.async(outer(), loop=self.loop)
test_utils.run_briefly(self.loop)
f.cancel()
- with self.assertRaises(futures.CancelledError):
+ with self.assertRaises(asyncio.CancelledError):
self.loop.run_until_complete(f)
waiter.set_result(None)
test_utils.run_briefly(self.loop)
self.assertEqual(proof, 1)
def test_shield_gather(self):
- child1 = futures.Future(loop=self.loop)
- child2 = futures.Future(loop=self.loop)
- parent = tasks.gather(child1, child2, loop=self.loop)
- outer = tasks.shield(parent, loop=self.loop)
+ child1 = asyncio.Future(loop=self.loop)
+ child2 = asyncio.Future(loop=self.loop)
+ parent = asyncio.gather(child1, child2, loop=self.loop)
+ outer = asyncio.shield(parent, loop=self.loop)
test_utils.run_briefly(self.loop)
outer.cancel()
test_utils.run_briefly(self.loop)
self.assertEqual(parent.result(), [1, 2])
def test_gather_shield(self):
- child1 = futures.Future(loop=self.loop)
- child2 = futures.Future(loop=self.loop)
- inner1 = tasks.shield(child1, loop=self.loop)
- inner2 = tasks.shield(child2, loop=self.loop)
- parent = tasks.gather(inner1, inner2, loop=self.loop)
+ child1 = asyncio.Future(loop=self.loop)
+ child2 = asyncio.Future(loop=self.loop)
+ inner1 = asyncio.shield(child1, loop=self.loop)
+ inner2 = asyncio.shield(child2, loop=self.loop)
+ parent = asyncio.gather(inner1, inner2, loop=self.loop)
test_utils.run_briefly(self.loop)
parent.cancel()
# This should cancel inner1 and inner2 but bot child1 and child2.
test_utils.run_briefly(self.loop)
- self.assertIsInstance(parent.exception(), futures.CancelledError)
+ self.assertIsInstance(parent.exception(), asyncio.CancelledError)
self.assertTrue(inner1.cancelled())
self.assertTrue(inner2.cancelled())
child1.set_result(1)
test_utils.run_briefly(loop)
def _check_success(self, **kwargs):
- a, b, c = [futures.Future(loop=self.one_loop) for i in range(3)]
- fut = tasks.gather(*self.wrap_futures(a, b, c), **kwargs)
+ a, b, c = [asyncio.Future(loop=self.one_loop) for i in range(3)]
+ fut = asyncio.gather(*self.wrap_futures(a, b, c), **kwargs)
cb = Mock()
fut.add_done_callback(cb)
b.set_result(1)
self._check_success(return_exceptions=True)
def test_one_exception(self):
- a, b, c, d, e = [futures.Future(loop=self.one_loop) for i in range(5)]
- fut = tasks.gather(*self.wrap_futures(a, b, c, d, e))
+ a, b, c, d, e = [asyncio.Future(loop=self.one_loop) for i in range(5)]
+ fut = asyncio.gather(*self.wrap_futures(a, b, c, d, e))
cb = Mock()
fut.add_done_callback(cb)
exc = ZeroDivisionError()
e.exception()
def test_return_exceptions(self):
- a, b, c, d = [futures.Future(loop=self.one_loop) for i in range(4)]
- fut = tasks.gather(*self.wrap_futures(a, b, c, d),
+ a, b, c, d = [asyncio.Future(loop=self.one_loop) for i in range(4)]
+ fut = asyncio.gather(*self.wrap_futures(a, b, c, d),
return_exceptions=True)
cb = Mock()
fut.add_done_callback(cb)
return futures
def _check_empty_sequence(self, seq_or_iter):
- events.set_event_loop(self.one_loop)
- self.addCleanup(events.set_event_loop, None)
- fut = tasks.gather(*seq_or_iter)
- self.assertIsInstance(fut, futures.Future)
+ asyncio.set_event_loop(self.one_loop)
+ self.addCleanup(asyncio.set_event_loop, None)
+ fut = asyncio.gather(*seq_or_iter)
+ self.assertIsInstance(fut, asyncio.Future)
self.assertIs(fut._loop, self.one_loop)
self._run_loop(self.one_loop)
self.assertTrue(fut.done())
self.assertEqual(fut.result(), [])
- fut = tasks.gather(*seq_or_iter, loop=self.other_loop)
+ fut = asyncio.gather(*seq_or_iter, loop=self.other_loop)
self.assertIs(fut._loop, self.other_loop)
def test_constructor_empty_sequence(self):
self._check_empty_sequence(iter(""))
def test_constructor_heterogenous_futures(self):
- fut1 = futures.Future(loop=self.one_loop)
- fut2 = futures.Future(loop=self.other_loop)
+ fut1 = asyncio.Future(loop=self.one_loop)
+ fut2 = asyncio.Future(loop=self.other_loop)
with self.assertRaises(ValueError):
- tasks.gather(fut1, fut2)
+ asyncio.gather(fut1, fut2)
with self.assertRaises(ValueError):
- tasks.gather(fut1, loop=self.other_loop)
+ asyncio.gather(fut1, loop=self.other_loop)
def test_constructor_homogenous_futures(self):
- children = [futures.Future(loop=self.other_loop) for i in range(3)]
- fut = tasks.gather(*children)
+ children = [asyncio.Future(loop=self.other_loop) for i in range(3)]
+ fut = asyncio.gather(*children)
self.assertIs(fut._loop, self.other_loop)
self._run_loop(self.other_loop)
self.assertFalse(fut.done())
- fut = tasks.gather(*children, loop=self.other_loop)
+ fut = asyncio.gather(*children, loop=self.other_loop)
self.assertIs(fut._loop, self.other_loop)
self._run_loop(self.other_loop)
self.assertFalse(fut.done())
def test_one_cancellation(self):
- a, b, c, d, e = [futures.Future(loop=self.one_loop) for i in range(5)]
- fut = tasks.gather(a, b, c, d, e)
+ a, b, c, d, e = [asyncio.Future(loop=self.one_loop) for i in range(5)]
+ fut = asyncio.gather(a, b, c, d, e)
cb = Mock()
fut.add_done_callback(cb)
a.set_result(1)
self.assertTrue(fut.done())
cb.assert_called_once_with(fut)
self.assertFalse(fut.cancelled())
- self.assertIsInstance(fut.exception(), futures.CancelledError)
+ self.assertIsInstance(fut.exception(), asyncio.CancelledError)
# Does nothing
c.set_result(3)
d.cancel()
e.exception()
def test_result_exception_one_cancellation(self):
- a, b, c, d, e, f = [futures.Future(loop=self.one_loop)
+ a, b, c, d, e, f = [asyncio.Future(loop=self.one_loop)
for i in range(6)]
- fut = tasks.gather(a, b, c, d, e, f, return_exceptions=True)
+ fut = asyncio.gather(a, b, c, d, e, f, return_exceptions=True)
cb = Mock()
fut.add_done_callback(cb)
a.set_result(1)
rte = RuntimeError()
f.set_exception(rte)
res = self.one_loop.run_until_complete(fut)
- self.assertIsInstance(res[2], futures.CancelledError)
- self.assertIsInstance(res[4], futures.CancelledError)
+ self.assertIsInstance(res[2], asyncio.CancelledError)
+ self.assertIsInstance(res[4], asyncio.CancelledError)
res[2] = res[4] = None
self.assertEqual(res, [1, zde, None, 3, None, rte])
cb.assert_called_once_with(fut)
def setUp(self):
super().setUp()
- events.set_event_loop(self.one_loop)
+ asyncio.set_event_loop(self.one_loop)
def tearDown(self):
- events.set_event_loop(None)
+ asyncio.set_event_loop(None)
super().tearDown()
def wrap_futures(self, *futures):
coros = []
for fut in futures:
- @tasks.coroutine
+ @asyncio.coroutine
def coro(fut=fut):
return (yield from fut)
coros.append(coro())
return coros
def test_constructor_loop_selection(self):
- @tasks.coroutine
+ @asyncio.coroutine
def coro():
return 'abc'
gen1 = coro()
gen2 = coro()
- fut = tasks.gather(gen1, gen2)
+ fut = asyncio.gather(gen1, gen2)
self.assertIs(fut._loop, self.one_loop)
gen1.close()
gen2.close()
gen3 = coro()
gen4 = coro()
- fut = tasks.gather(gen3, gen4, loop=self.other_loop)
+ fut = asyncio.gather(gen3, gen4, loop=self.other_loop)
self.assertIs(fut._loop, self.other_loop)
gen3.close()
gen4.close()
def test_cancellation_broadcast(self):
# Cancelling outer() cancels all children.
proof = 0
- waiter = futures.Future(loop=self.one_loop)
+ waiter = asyncio.Future(loop=self.one_loop)
- @tasks.coroutine
+ @asyncio.coroutine
def inner():
nonlocal proof
yield from waiter
proof += 1
- child1 = tasks.async(inner(), loop=self.one_loop)
- child2 = tasks.async(inner(), loop=self.one_loop)
+ child1 = asyncio.async(inner(), loop=self.one_loop)
+ child2 = asyncio.async(inner(), loop=self.one_loop)
gatherer = None
- @tasks.coroutine
+ @asyncio.coroutine
def outer():
nonlocal proof, gatherer
- gatherer = tasks.gather(child1, child2, loop=self.one_loop)
+ gatherer = asyncio.gather(child1, child2, loop=self.one_loop)
yield from gatherer
proof += 100
- f = tasks.async(outer(), loop=self.one_loop)
+ f = asyncio.async(outer(), loop=self.one_loop)
test_utils.run_briefly(self.one_loop)
self.assertTrue(f.cancel())
- with self.assertRaises(futures.CancelledError):
+ with self.assertRaises(asyncio.CancelledError):
self.one_loop.run_until_complete(f)
self.assertFalse(gatherer.cancel())
self.assertTrue(waiter.cancelled())
def test_exception_marking(self):
# Test for the first line marked "Mark exception retrieved."
- @tasks.coroutine
+ @asyncio.coroutine
def inner(f):
yield from f
raise RuntimeError('should not be ignored')
- a = futures.Future(loop=self.one_loop)
- b = futures.Future(loop=self.one_loop)
+ a = asyncio.Future(loop=self.one_loop)
+ b = asyncio.Future(loop=self.one_loop)
- @tasks.coroutine
+ @asyncio.coroutine
def outer():
- yield from tasks.gather(inner(a), inner(b), loop=self.one_loop)
+ yield from asyncio.gather(inner(a), inner(b), loop=self.one_loop)
- f = tasks.async(outer(), loop=self.one_loop)
+ f = asyncio.async(outer(), loop=self.one_loop)
test_utils.run_briefly(self.one_loop)
a.set_result(None)
test_utils.run_briefly(self.one_loop)
import unittest
import unittest.mock
-from asyncio import transports
+import asyncio
class TransportTests(unittest.TestCase):
def test_ctor_extra_is_none(self):
- transport = transports.Transport()
+ transport = asyncio.Transport()
self.assertEqual(transport._extra, {})
def test_get_extra_info(self):
- transport = transports.Transport({'extra': 'info'})
+ transport = asyncio.Transport({'extra': 'info'})
self.assertEqual('info', transport.get_extra_info('extra'))
self.assertIsNone(transport.get_extra_info('unknown'))
self.assertIs(default, transport.get_extra_info('unknown', default))
def test_writelines(self):
- transport = transports.Transport()
+ transport = asyncio.Transport()
transport.write = unittest.mock.Mock()
transport.writelines([b'line1',
transport.write.assert_called_with(b'line1line2line3')
def test_not_implemented(self):
- transport = transports.Transport()
+ transport = asyncio.Transport()
self.assertRaises(NotImplementedError,
transport.set_write_buffer_limits)
self.assertRaises(NotImplementedError, transport.abort)
def test_dgram_not_implemented(self):
- transport = transports.DatagramTransport()
+ transport = asyncio.DatagramTransport()
self.assertRaises(NotImplementedError, transport.sendto, 'data')
self.assertRaises(NotImplementedError, transport.abort)
def test_subprocess_transport_not_implemented(self):
- transport = transports.SubprocessTransport()
+ transport = asyncio.SubprocessTransport()
self.assertRaises(NotImplementedError, transport.get_pid)
self.assertRaises(NotImplementedError, transport.get_returncode)
raise unittest.SkipTest('UNIX only')
-from asyncio import events
-from asyncio import futures
-from asyncio import protocols
+import asyncio
+from asyncio import log
from asyncio import test_utils
from asyncio import unix_events
class SelectorEventLoopTests(unittest.TestCase):
def setUp(self):
- self.loop = unix_events.SelectorEventLoop()
- events.set_event_loop(None)
+ self.loop = asyncio.SelectorEventLoop()
+ asyncio.set_event_loop(None)
def tearDown(self):
self.loop.close()
self.loop._handle_signal(signal.NSIG + 1, ())
def test_handle_signal_cancelled_handler(self):
- h = events.Handle(unittest.mock.Mock(), ())
+ h = asyncio.Handle(unittest.mock.Mock(), ())
h.cancel()
self.loop._signal_handlers[signal.NSIG + 1] = h
self.loop.remove_signal_handler = unittest.mock.Mock()
cb = lambda: True
self.loop.add_signal_handler(signal.SIGHUP, cb)
h = self.loop._signal_handlers.get(signal.SIGHUP)
- self.assertIsInstance(h, events.Handle)
+ self.assertIsInstance(h, asyncio.Handle)
self.assertEqual(h._callback, cb)
@unittest.mock.patch('asyncio.unix_events.signal')
def setUp(self):
self.loop = test_utils.TestLoop()
- self.protocol = test_utils.make_test_protocol(protocols.Protocol)
+ self.protocol = test_utils.make_test_protocol(asyncio.Protocol)
self.pipe = unittest.mock.Mock(spec_set=io.RawIOBase)
self.pipe.fileno.return_value = 5
self.protocol.connection_made.assert_called_with(tr)
def test_ctor_with_waiter(self):
- fut = futures.Future(loop=self.loop)
+ fut = asyncio.Future(loop=self.loop)
unix_events._UnixReadPipeTransport(
self.loop, self.pipe, self.protocol, fut)
test_utils.run_briefly(self.loop)
def setUp(self):
self.loop = test_utils.TestLoop()
- self.protocol = test_utils.make_test_protocol(protocols.BaseProtocol)
+ self.protocol = test_utils.make_test_protocol(asyncio.BaseProtocol)
self.pipe = unittest.mock.Mock(spec_set=io.RawIOBase)
self.pipe.fileno.return_value = 5
self.protocol.connection_made.assert_called_with(tr)
def test_ctor_with_waiter(self):
- fut = futures.Future(loop=self.loop)
+ fut = asyncio.Future(loop=self.loop)
tr = unix_events._UnixWritePipeTransport(
self.loop, self.pipe, self.protocol, fut)
self.loop.assert_reader(5, tr._read_ready)
def test_not_implemented(self):
f = unittest.mock.Mock()
- watcher = unix_events.AbstractChildWatcher()
+ watcher = asyncio.AbstractChildWatcher()
self.assertRaises(
NotImplementedError, watcher.add_child_handler, f, f)
self.assertRaises(
class ChildWatcherTestsMixin:
- ignore_warnings = unittest.mock.patch.object(unix_events.logger, "warning")
+ ignore_warnings = unittest.mock.patch.object(log.logger, "warning")
def setUp(self):
self.loop = test_utils.TestLoop()
self.watcher.attach_loop(self.loop)
def waitpid(self, pid, flags):
- if isinstance(self.watcher, unix_events.SafeChildWatcher) or pid != -1:
+ if isinstance(self.watcher, asyncio.SafeChildWatcher) or pid != -1:
self.assertGreater(pid, 0)
try:
if pid < 0:
# raise an exception
m.waitpid.side_effect = ValueError
- with unittest.mock.patch.object(unix_events.logger,
+ with unittest.mock.patch.object(log.logger,
"exception") as m_exception:
self.assertEqual(self.watcher._sig_chld(), None)
self.watcher._sig_chld()
callback.assert_called(m.waitpid)
- if isinstance(self.watcher, unix_events.FastChildWatcher):
+ if isinstance(self.watcher, asyncio.FastChildWatcher):
# here the FastChildWatche enters a deadlock
# (there is no way to prevent it)
self.assertFalse(callback.called)
self.watcher.add_child_handler(64, callback1)
self.assertEqual(len(self.watcher._callbacks), 1)
- if isinstance(self.watcher, unix_events.FastChildWatcher):
+ if isinstance(self.watcher, asyncio.FastChildWatcher):
self.assertEqual(len(self.watcher._zombies), 1)
with unittest.mock.patch.object(
m_remove_signal_handler.assert_called_once_with(
signal.SIGCHLD)
self.assertFalse(self.watcher._callbacks)
- if isinstance(self.watcher, unix_events.FastChildWatcher):
+ if isinstance(self.watcher, asyncio.FastChildWatcher):
self.assertFalse(self.watcher._zombies)
class SafeChildWatcherTests (ChildWatcherTestsMixin, unittest.TestCase):
def create_watcher(self):
- return unix_events.SafeChildWatcher()
+ return asyncio.SafeChildWatcher()
class FastChildWatcherTests (ChildWatcherTestsMixin, unittest.TestCase):
def create_watcher(self):
- return unix_events.FastChildWatcher()
+ return asyncio.FastChildWatcher()
class PolicyTests(unittest.TestCase):
def create_policy(self):
- return unix_events.DefaultEventLoopPolicy()
+ return asyncio.DefaultEventLoopPolicy()
def test_get_child_watcher(self):
policy = self.create_policy()
self.assertIsNone(policy._watcher)
watcher = policy.get_child_watcher()
- self.assertIsInstance(watcher, unix_events.SafeChildWatcher)
+ self.assertIsInstance(watcher, asyncio.SafeChildWatcher)
self.assertIs(policy._watcher, watcher)
def test_get_child_watcher_after_set(self):
policy = self.create_policy()
- watcher = unix_events.FastChildWatcher()
+ watcher = asyncio.FastChildWatcher()
policy.set_child_watcher(watcher)
self.assertIs(policy._watcher, watcher)
self.assertIsNone(policy._watcher)
watcher = policy.get_child_watcher()
- self.assertIsInstance(watcher, unix_events.SafeChildWatcher)
+ self.assertIsInstance(watcher, asyncio.SafeChildWatcher)
self.assertIs(watcher._loop, loop)
loop.close()
policy.set_event_loop(policy.new_event_loop())
self.assertIsInstance(policy.get_event_loop(),
- events.AbstractEventLoop)
+ asyncio.AbstractEventLoop)
watcher = policy.get_child_watcher()
- self.assertIsInstance(watcher, unix_events.SafeChildWatcher)
+ self.assertIsInstance(watcher, asyncio.SafeChildWatcher)
self.assertIsNone(watcher._loop)
policy.get_event_loop().close()
import _winapi
import asyncio
-
-from asyncio import windows_events
-from asyncio import futures
-from asyncio import protocols
-from asyncio import streams
-from asyncio import transports
from asyncio import test_utils
from asyncio import _overlapped
+from asyncio import windows_events
-class UpperProto(protocols.Protocol):
+class UpperProto(asyncio.Protocol):
def __init__(self):
self.buf = []
class ProactorTests(unittest.TestCase):
def setUp(self):
- self.loop = windows_events.ProactorEventLoop()
+ self.loop = asyncio.ProactorEventLoop()
asyncio.set_event_loop(None)
def tearDown(self):
def test_close(self):
a, b = self.loop._socketpair()
- trans = self.loop._make_socket_transport(a, protocols.Protocol())
+ trans = self.loop._make_socket_transport(a, asyncio.Protocol())
f = asyncio.async(self.loop.sock_recv(b, 100))
trans.close()
self.loop.run_until_complete(f)
with self.assertRaises(FileNotFoundError):
yield from self.loop.create_pipe_connection(
- protocols.Protocol, ADDRESS)
+ asyncio.Protocol, ADDRESS)
[server] = yield from self.loop.start_serving_pipe(
UpperProto, ADDRESS)
clients = []
for i in range(5):
- stream_reader = streams.StreamReader(loop=self.loop)
- protocol = streams.StreamReaderProtocol(stream_reader)
+ stream_reader = asyncio.StreamReader(loop=self.loop)
+ protocol = asyncio.StreamReaderProtocol(stream_reader)
trans, proto = yield from self.loop.create_pipe_connection(
lambda: protocol, ADDRESS)
- self.assertIsInstance(trans, transports.Transport)
+ self.assertIsInstance(trans, asyncio.Transport)
self.assertEqual(protocol, proto)
clients.append((stream_reader, trans))
with self.assertRaises(FileNotFoundError):
yield from self.loop.create_pipe_connection(
- protocols.Protocol, ADDRESS)
+ asyncio.Protocol, ADDRESS)
return 'done'
f = self.loop._proactor.wait_for_handle(event, 10)
f.cancel()
start = self.loop.time()
- with self.assertRaises(futures.CancelledError):
+ with self.assertRaises(asyncio.CancelledError):
self.loop.run_until_complete(f)
elapsed = self.loop.time() - start
self.assertTrue(0 <= elapsed < 0.1, elapsed)