Commit d0cdeaab authored by Raymond Hettinger's avatar Raymond Hettinger Committed by GitHub

bpo-32554: Deprecate hashing arbitrary types in random.seed() (GH-15382)

parent 4109263a
...@@ -86,6 +86,11 @@ Bookkeeping functions ...@@ -86,6 +86,11 @@ Bookkeeping functions
.. versionchanged:: 3.2 .. versionchanged:: 3.2
Moved to the version 2 scheme which uses all of the bits in a string seed. Moved to the version 2 scheme which uses all of the bits in a string seed.
.. deprecated:: 3.9
In the future, the *seed* must be one of the following types:
*NoneType*, :class:`int`, :class:`float`, :class:`str`,
:class:`bytes`, or :class:`bytearray`.
.. function:: getstate() .. function:: getstate()
Return an object capturing the current internal state of the generator. This Return an object capturing the current internal state of the generator. This
...@@ -316,6 +321,11 @@ Alternative Generator ...@@ -316,6 +321,11 @@ Alternative Generator
Class that implements the default pseudo-random number generator used by the Class that implements the default pseudo-random number generator used by the
:mod:`random` module. :mod:`random` module.
.. deprecated:: 3.9
In the future, the *seed* must be one of the following types:
:class:`NoneType`, :class:`int`, :class:`float`, :class:`str`,
:class:`bytes`, or :class:`bytearray`.
.. class:: SystemRandom([seed]) .. class:: SystemRandom([seed])
Class that uses the :func:`os.urandom` function for generating random numbers Class that uses the :func:`os.urandom` function for generating random numbers
......
...@@ -169,6 +169,12 @@ Deprecated ...@@ -169,6 +169,12 @@ Deprecated
of Python. For the majority of use cases users can leverage the Abstract Syntax of Python. For the majority of use cases users can leverage the Abstract Syntax
Tree (AST) generation and compilation stage, using the :mod:`ast` module. Tree (AST) generation and compilation stage, using the :mod:`ast` module.
* The :mod:`random` module currently accepts any hashable type as a
possible seed value. Unfortunately, some of those types are not
guaranteed to have a deterministic hash value. After Python 3.9,
the module will restrict its seeds to *None*, :class:`int`,
:class:`float`, :class:`str`, :class:`bytes`, and :class:`bytearray`.
Removed Removed
======= =======
......
...@@ -121,7 +121,10 @@ class Random(_random.Random): ...@@ -121,7 +121,10 @@ class Random(_random.Random):
break break
def seed(self, a=None, version=2): def seed(self, a=None, version=2):
"""Initialize internal state from hashable object. """Initialize internal state from a seed.
The only supported seed types are None, int, float,
str, bytes, and bytearray.
None or no argument seeds from current time or from an operating None or no argument seeds from current time or from an operating
system specific randomness source if available. system specific randomness source if available.
...@@ -143,12 +146,20 @@ class Random(_random.Random): ...@@ -143,12 +146,20 @@ class Random(_random.Random):
x ^= len(a) x ^= len(a)
a = -2 if x == -1 else x a = -2 if x == -1 else x
if version == 2 and isinstance(a, (str, bytes, bytearray)): elif version == 2 and isinstance(a, (str, bytes, bytearray)):
if isinstance(a, str): if isinstance(a, str):
a = a.encode() a = a.encode()
a += _sha512(a).digest() a += _sha512(a).digest()
a = int.from_bytes(a, 'big') a = int.from_bytes(a, 'big')
elif not isinstance(a, (type(None), int, float, str, bytes, bytearray)):
_warn('Seeding based on hashing is deprecated\n'
'since Python 3.9 and will be removed in a subsequent '
'version. The only \n'
'supported seed types are: None, '
'int, float, str, bytes, and bytearray.',
DeprecationWarning, 2)
super().seed(a) super().seed(a)
self.gauss_next = None self.gauss_next = None
......
Deprecate having random.seed() call hash on arbitrary types.
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment