Skip to content

Commit

Permalink
Extract the SYSTEMROOT handler and document it.
Browse files Browse the repository at this point in the history
  • Loading branch information
jaraco committed Jan 6, 2022
1 parent 6a1a7e6 commit c51f512
Showing 1 changed file with 16 additions and 4 deletions.
20 changes: 16 additions & 4 deletions setuptools/tests/test_distutils_adoption.py
Original file line number Diff line number Diff line change
Expand Up @@ -42,12 +42,24 @@ def popen_text(call):
if sys.version_info < (3, 7) else functools.partial(call, text=True)


def win_sr(env):
"""
On Windows, SYSTEMROOT must be present to avoid
> Fatal Python error: _Py_HashRandomization_Init: failed to
> get random numbers to initialize Python
"""
if env is None:
return
if platform.system() == 'Windows':
env['SYSTEMROOT'] = os.environ['SYSTEMROOT']
return env


def find_distutils(venv, imports='distutils', env=None, **kwargs):
py_cmd = 'import {imports}; print(distutils.__file__)'.format(**locals())
cmd = ['python', '-c', py_cmd]
if platform.system() == 'Windows':
env['SYSTEMROOT'] = os.environ['SYSTEMROOT']
return popen_text(venv.run)(cmd, env=env, **kwargs)
return popen_text(venv.run)(cmd, env=win_sr(env), **kwargs)


def count_meta_path(venv, env=None):
Expand All @@ -58,7 +70,7 @@ def count_meta_path(venv, env=None):
print(len(list(filter(is_distutils, sys.meta_path))))
""")
cmd = ['python', '-c', py_cmd]
return int(popen_text(venv.run)(cmd, env=env))
return int(popen_text(venv.run)(cmd, env=win_sr(env)))


def test_distutils_stdlib(venv):
Expand Down

0 comments on commit c51f512

Please sign in to comment.