summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Doc/library/typing.rst6
-rw-r--r--Lib/test/test_typing.py5
-rw-r--r--Lib/typing.py2
3 files changed, 9 insertions, 4 deletions
diff --git a/Doc/library/typing.rst b/Doc/library/typing.rst
index 324abde..42a89ce 100644
--- a/Doc/library/typing.rst
+++ b/Doc/library/typing.rst
@@ -1687,9 +1687,9 @@ Introspection helpers
For a typing object of the form ``X[Y, Z, ...]`` these functions return
``X`` and ``(Y, Z, ...)``. If ``X`` is a generic alias for a builtin or
:mod:`collections` class, it gets normalized to the original class.
- If ``X`` is a :class:`Union` contained in another generic type,
- the order of ``(Y, Z, ...)`` may be different from the order of
- the original arguments ``[Y, Z, ...]`` due to type caching.
+ If ``X`` is a :class:`Union` or :class:`Literal` contained in another
+ generic type, the order of ``(Y, Z, ...)`` may be different from the order
+ of the original arguments ``[Y, Z, ...]`` due to type caching.
For unsupported objects return ``None`` and ``()`` correspondingly.
Examples::
diff --git a/Lib/test/test_typing.py b/Lib/test/test_typing.py
index 9d82eec..13cf20e 100644
--- a/Lib/test/test_typing.py
+++ b/Lib/test/test_typing.py
@@ -573,6 +573,11 @@ class LiteralTests(BaseTestCase):
self.assertEqual(Literal[1, 2], Literal[2, 1])
self.assertEqual(Literal[1, 2, 3], Literal[1, 2, 3, 3])
+ def test_hash(self):
+ self.assertEqual(hash(Literal[1]), hash(Literal[1]))
+ self.assertEqual(hash(Literal[1, 2]), hash(Literal[2, 1]))
+ self.assertEqual(hash(Literal[1, 2, 3]), hash(Literal[1, 2, 3, 3]))
+
def test_args(self):
self.assertEqual(Literal[1, 2, 3].__args__, (1, 2, 3))
self.assertEqual(Literal[1, 2, 3, 3].__args__, (1, 2, 3))
diff --git a/Lib/typing.py b/Lib/typing.py
index 14952ec..f5316ab 100644
--- a/Lib/typing.py
+++ b/Lib/typing.py
@@ -932,7 +932,7 @@ class _LiteralGenericAlias(_GenericAlias, _root=True):
return set(_value_and_type_iter(self.__args__)) == set(_value_and_type_iter(other.__args__))
def __hash__(self):
- return hash(tuple(_value_and_type_iter(self.__args__)))
+ return hash(frozenset(_value_and_type_iter(self.__args__)))
class Generic: