summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMiss Islington (bot) <31488909+miss-islington@users.noreply.github.com>2021-12-17 11:33:07 (GMT)
committerGitHub <noreply@github.com>2021-12-17 11:33:07 (GMT)
commit87539cc716fab47cd4f501f2441c4ab8e80bce6f (patch)
tree027ad2c5418f704749cd8e013685239bc5ae6ec0
parent9fe8fb74a1e21ab881c70111813266d67bfda016 (diff)
downloadcpython-87539cc716fab47cd4f501f2441c4ab8e80bce6f.zip
cpython-87539cc716fab47cd4f501f2441c4ab8e80bce6f.tar.gz
cpython-87539cc716fab47cd4f501f2441c4ab8e80bce6f.tar.bz2
bpo-45755: [typing] Reveal class attributes of generic in generic aliases in `dir()` (GH-29962)
(cherry picked from commit d6e13747161d7b634b47d2d3d212ed3be4a21fab) Co-authored-by: Ken Jin <28750310+Fidget-Spinner@users.noreply.github.com>
-rw-r--r--Lib/test/test_typing.py11
-rw-r--r--Lib/typing.py3
-rw-r--r--Misc/NEWS.d/next/Library/2021-12-07-21-55-22.bpo-45755.bRqKGa.rst3
3 files changed, 17 insertions, 0 deletions
diff --git a/Lib/test/test_typing.py b/Lib/test/test_typing.py
index fdec29e..82b6f8c 100644
--- a/Lib/test/test_typing.py
+++ b/Lib/test/test_typing.py
@@ -4994,6 +4994,17 @@ class SpecialAttrsTests(BaseTestCase):
loaded = pickle.loads(s)
self.assertIs(SpecialAttrsP, loaded)
+ def test_genericalias_dir(self):
+ class Foo(Generic[T]):
+ def bar(self):
+ pass
+ baz = 3
+ # The class attributes of the original class should be visible even
+ # in dir() of the GenericAlias. See bpo-45755.
+ self.assertIn('bar', dir(Foo[int]))
+ self.assertIn('baz', dir(Foo[int]))
+
+
class AllTests(BaseTestCase):
"""Tests for __all__."""
diff --git a/Lib/typing.py b/Lib/typing.py
index b743d40..2522547 100644
--- a/Lib/typing.py
+++ b/Lib/typing.py
@@ -983,6 +983,9 @@ class _BaseGenericAlias(_Final, _root=True):
raise TypeError("Subscripted generics cannot be used with"
" class and instance checks")
+ def __dir__(self):
+ return list(set(super().__dir__()
+ + [attr for attr in dir(self.__origin__) if not _is_dunder(attr)]))
# Special typing constructs Union, Optional, Generic, Callable and Tuple
# use three special attributes for internal bookkeeping of generic types:
diff --git a/Misc/NEWS.d/next/Library/2021-12-07-21-55-22.bpo-45755.bRqKGa.rst b/Misc/NEWS.d/next/Library/2021-12-07-21-55-22.bpo-45755.bRqKGa.rst
new file mode 100644
index 0000000..e5201b0
--- /dev/null
+++ b/Misc/NEWS.d/next/Library/2021-12-07-21-55-22.bpo-45755.bRqKGa.rst
@@ -0,0 +1,3 @@
+:mod:`typing` generic aliases now reveal the class attributes of the
+original generic class when passed to ``dir()``. This was the behavior up to
+Python 3.6, but was changed in 3.7-3.9.