[Python-checkins] bpo-38431: Fix __repr__ method of InitVar to work with typing objects. (GH-16702)

Serhiy Storchaka webhook-mailer at python.org
Sun Oct 13 07:45:40 EDT 2019


https://github.com/python/cpython/commit/793cb85437299a3da3d74fe65480d720af330cbb
commit: 793cb85437299a3da3d74fe65480d720af330cbb
branch: master
author: Samuel Colvin <samcolvin at gmail.com>
committer: Serhiy Storchaka <storchaka at gmail.com>
date: 2019-10-13T14:45:36+03:00
summary:

bpo-38431: Fix __repr__ method of InitVar to work with typing objects. (GH-16702)

files:
A Misc/NEWS.d/next/Library/2019-10-10-16-53-00.bpo-38431.d5wzNp.rst
M Lib/dataclasses.py
M Lib/test/test_dataclasses.py

diff --git a/Lib/dataclasses.py b/Lib/dataclasses.py
index 9135b07c9f259..91c1f6f80fc68 100644
--- a/Lib/dataclasses.py
+++ b/Lib/dataclasses.py
@@ -206,7 +206,12 @@ def __init__(self, type):
         self.type = type
 
     def __repr__(self):
-        return f'dataclasses.InitVar[{self.type.__name__}]'
+        if isinstance(self.type, type):
+            type_name = self.type.__name__
+        else:
+            # typing objects, e.g. List[int]
+            type_name = repr(self.type)
+        return f'dataclasses.InitVar[{type_name}]'
 
     def __class_getitem__(cls, type):
         return InitVar(type)
diff --git a/Lib/test/test_dataclasses.py b/Lib/test/test_dataclasses.py
index 037bf4c221427..238335e7d9eda 100644
--- a/Lib/test/test_dataclasses.py
+++ b/Lib/test/test_dataclasses.py
@@ -1102,6 +1102,8 @@ def test_init_var_preserve_type(self):
 
         # Make sure the repr is correct.
         self.assertEqual(repr(InitVar[int]), 'dataclasses.InitVar[int]')
+        self.assertEqual(repr(InitVar[List[int]]),
+                         'dataclasses.InitVar[typing.List[int]]')
 
     def test_init_var_inheritance(self):
         # Note that this deliberately tests that a dataclass need not
diff --git a/Misc/NEWS.d/next/Library/2019-10-10-16-53-00.bpo-38431.d5wzNp.rst b/Misc/NEWS.d/next/Library/2019-10-10-16-53-00.bpo-38431.d5wzNp.rst
new file mode 100644
index 0000000000000..c2f860d804c13
--- /dev/null
+++ b/Misc/NEWS.d/next/Library/2019-10-10-16-53-00.bpo-38431.d5wzNp.rst
@@ -0,0 +1 @@
+Fix ``__repr__`` method for :class:`dataclasses.InitVar` to support typing objects, patch by Samuel Colvin.



More information about the Python-checkins mailing list