Merge 3.5 (issue #28372)

This commit is contained in:
Yury Selivanov 2016-10-05 19:33:36 -04:00
commit 996dd4a666
3 changed files with 55 additions and 0 deletions

View file

@ -1,5 +1,6 @@
"""Tests for events.py."""
import collections.abc
import functools
import gc
import io
@ -25,6 +26,7 @@ if sys.platform != 'win32':
import tty
import asyncio
from asyncio import coroutines
from asyncio import proactor_events
from asyncio import selector_events
from asyncio import sslproto
@ -2380,6 +2382,38 @@ class HandleTests(test_utils.TestCase):
h = loop.call_later(0, noop)
check_source_traceback(h)
@unittest.skipUnless(hasattr(collections.abc, 'Coroutine'),
'No collections.abc.Coroutine')
def test_coroutine_like_object_debug_formatting(self):
# Test that asyncio can format coroutines that are instances of
# collections.abc.Coroutine, but lack cr_core or gi_code attributes
# (such as ones compiled with Cython).
class Coro:
__name__ = 'AAA'
def send(self, v):
pass
def throw(self, *exc):
pass
def close(self):
pass
def __await__(self):
pass
coro = Coro()
self.assertTrue(asyncio.iscoroutine(coro))
self.assertEqual(coroutines._format_coroutine(coro), 'AAA()')
coro.__qualname__ = 'BBB'
self.assertEqual(coroutines._format_coroutine(coro), 'BBB()')
coro.cr_running = True
self.assertEqual(coroutines._format_coroutine(coro), 'BBB() running')
class TimerTests(unittest.TestCase):