summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGuido van Rossum <guido@python.org>2016-10-29 12:44:31 -0700
committerGuido van Rossum <guido@python.org>2016-10-29 12:44:31 -0700
commitfd274c47aa99fc0add7457a0ee4f3d4228bab1fe (patch)
tree9f3557a474f4c323fac90dcea626c5df8525789a
parent27c22f900c8267148d2ffecce8f0a474774420f1 (diff)
parentc6c1c6ef79b359ca4f6b30c0c91514e9ea486b9c (diff)
downloadcpython-git-fd274c47aa99fc0add7457a0ee4f3d4228bab1fe.tar.gz
Issue #28556: updates to typing.py (fix copy, deepcopy, pickle) (3.6->3.7)
-rw-r--r--Lib/test/test_typing.py19
-rw-r--r--Lib/typing.py8
2 files changed, 27 insertions, 0 deletions
diff --git a/Lib/test/test_typing.py b/Lib/test/test_typing.py
index 8e0a8c522f..b50f36679d 100644
--- a/Lib/test/test_typing.py
+++ b/Lib/test/test_typing.py
@@ -4,6 +4,7 @@ import pickle
import re
import sys
from unittest import TestCase, main, skipUnless, SkipTest
+from copy import copy, deepcopy
from typing import Any
from typing import TypeVar, AnyStr
@@ -845,6 +846,24 @@ class GenericTests(BaseTestCase):
self.assertEqual(x.foo, 42)
self.assertEqual(x.bar, 'abc')
self.assertEqual(x.__dict__, {'foo': 42, 'bar': 'abc'})
+ simples = [Any, Union, Tuple, Callable, ClassVar, List, typing.Iterable]
+ for s in simples:
+ for proto in range(pickle.HIGHEST_PROTOCOL + 1):
+ z = pickle.dumps(s, proto)
+ x = pickle.loads(z)
+ self.assertEqual(s, x)
+
+ def test_copy_and_deepcopy(self):
+ T = TypeVar('T')
+ class Node(Generic[T]): ...
+ things = [Union[T, int], Tuple[T, int], Callable[..., T], Callable[[int], int],
+ Tuple[Any, Any], Node[T], Node[int], Node[Any], typing.Iterable[T],
+ typing.Iterable[Any], typing.Iterable[int], typing.Dict[int, str],
+ typing.Dict[T, Any], ClassVar[int], ClassVar[List[T]], Tuple['T', 'T'],
+ Union['T', int], List['T'], typing.Mapping['T', int]]
+ for t in things + [Any]:
+ self.assertEqual(t, copy(t))
+ self.assertEqual(t, deepcopy(t))
def test_errors(self):
with self.assertRaises(TypeError):
diff --git a/Lib/typing.py b/Lib/typing.py
index bda4ea59c2..572708b5ed 100644
--- a/Lib/typing.py
+++ b/Lib/typing.py
@@ -190,6 +190,9 @@ class _FinalTypingBase(_TypingBase, _root=True):
return self
raise TypeError("Cannot instantiate %r" % cls)
+ def __reduce__(self):
+ return _trim_name(type(self).__name__)
+
class _ForwardRef(_TypingBase, _root=True):
"""Wrapper to hold a forward reference."""
@@ -1051,6 +1054,11 @@ class GenericMeta(TypingMeta, abc.ABCMeta):
# classes are supposed to be rare anyways.
return issubclass(instance.__class__, self)
+ def __copy__(self):
+ return self.__class__(self.__name__, self.__bases__, dict(self.__dict__),
+ self.__parameters__, self.__args__, self.__origin__,
+ self.__extra__, self.__orig_bases__)
+
# Prevent checks for Generic to crash when defining Generic.
Generic = None