diff options
author | Guido van Rossum <guido@dropbox.com> | 2015-09-04 12:05:03 -0700 |
---|---|---|
committer | Guido van Rossum <guido@dropbox.com> | 2015-09-04 12:05:03 -0700 |
commit | 82b63fadd2c02fe7a65a22de473ad86409da8b59 (patch) | |
tree | 0149fefd013318077ed59f1f7ee2b158451e0966 | |
parent | d05f49924d4ef620d32d0f66f993de2ffc5da228 (diff) | |
parent | 647bae6c520237b01d75e51adbc6048d95db30bc (diff) | |
download | cpython-git-82b63fadd2c02fe7a65a22de473ad86409da8b59.tar.gz |
Issue #24635: Fixed flakiness in test_typing.py. (Merge from 3.5.)
-rw-r--r-- | Lib/test/test_typing.py | 17 | ||||
-rw-r--r-- | Lib/typing.py | 15 | ||||
-rw-r--r-- | Misc/NEWS | 3 |
3 files changed, 27 insertions, 8 deletions
diff --git a/Lib/test/test_typing.py b/Lib/test/test_typing.py index b34007dc22..1461cfbe48 100644 --- a/Lib/test/test_typing.py +++ b/Lib/test/test_typing.py @@ -436,12 +436,14 @@ class CallableTests(TestCase): c() def test_callable_instance_works(self): - f = lambda: None + def f(): + pass assert isinstance(f, Callable) assert not isinstance(None, Callable) def test_callable_instance_type_error(self): - f = lambda: None + def f(): + pass with self.assertRaises(TypeError): assert isinstance(f, Callable[[], None]) with self.assertRaises(TypeError): @@ -674,7 +676,9 @@ class GenericTests(TestCase): T = TypeVar('T') class Node(Generic[T]): - def __init__(self, label: T, left: 'Node[T]' = None, right: 'Node[T]' = None): + def __init__(self, label: T, + left: 'Node[T]' = None, + right: 'Node[T]' = None): self.label = label # type: T self.left = left # type: Optional[Node[T]] self.right = right # type: Optional[Node[T]] @@ -934,8 +938,15 @@ class CollectionsAbcTests(TestCase): def test_iterable(self): assert isinstance([], typing.Iterable) + # Due to ABC caching, the second time takes a separate code + # path and could fail. So call this a few times. + assert isinstance([], typing.Iterable) + assert isinstance([], typing.Iterable) assert isinstance([], typing.Iterable[int]) assert not isinstance(42, typing.Iterable) + # Just in case, also test issubclass() a few times. + assert issubclass(list, typing.Iterable) + assert issubclass(list, typing.Iterable) def test_iterator(self): it = iter([]) diff --git a/Lib/typing.py b/Lib/typing.py index ddaec3e725..1a4982ead9 100644 --- a/Lib/typing.py +++ b/Lib/typing.py @@ -1,7 +1,3 @@ -# TODO: -# - Generic[T, T] is invalid -# - Look for TODO below - # TODO nits: # Get rid of asserts that are the caller's fault. # Docstrings (e.g. ABCs). @@ -963,7 +959,8 @@ class GenericMeta(TypingMeta, abc.ABCMeta): raise TypeError("Initial parameters must be " "type variables; got %s" % p) if len(set(params)) != len(params): - raise TypeError("All type variables in Generic[...] must be distinct.") + raise TypeError( + "All type variables in Generic[...] must be distinct.") else: if len(params) != len(self.__parameters__): raise TypeError("Cannot change parameter count from %d to %d" % @@ -987,6 +984,14 @@ class GenericMeta(TypingMeta, abc.ABCMeta): origin=self, extra=self.__extra__) + def __instancecheck__(self, instance): + # Since we extend ABC.__subclasscheck__ and + # ABC.__instancecheck__ inlines the cache checking done by the + # latter, we must extend __instancecheck__ too. For simplicity + # we just skip the cache check -- instance checks for generic + # classes are supposed to be rare anyways. + return self.__subclasscheck__(instance.__class__) + def __subclasscheck__(self, cls): if cls is Any: return True @@ -172,6 +172,9 @@ Core and Builtins Library ------- +- Issue #24635: Fixed a bug in typing.py where isinstance([], typing.Iterable) + would return True once, then False on subsequent calls. + - Issue #24989: Fixed buffer overread in BytesIO.readline() if a position is set beyond size. Based on patch by John Leitch. |