Close #12383: Fix subprocess module with env={}: don't copy the environment

variables, start with an empty environment.
This commit is contained in:
Victor Stinner 2011-06-21 17:18:38 +02:00
parent b7149cad04
commit f1512a2967
3 changed files with 20 additions and 8 deletions

View File

@ -1169,7 +1169,7 @@ class Popen(object):
# potential deadlocks, thus we do all this here. # potential deadlocks, thus we do all this here.
# and pass it to fork_exec() # and pass it to fork_exec()
if env: if env is not None:
env_list = [os.fsencode(k) + b'=' + os.fsencode(v) env_list = [os.fsencode(k) + b'=' + os.fsencode(v)
for k, v in env.items()] for k, v in env.items()]
else: else:

View File

@ -331,13 +331,22 @@ class ProcessTestCase(BaseTestCase):
def test_env(self): def test_env(self):
newenv = os.environ.copy() newenv = os.environ.copy()
newenv["FRUIT"] = "orange" newenv["FRUIT"] = "orange"
p = subprocess.Popen([sys.executable, "-c", with subprocess.Popen([sys.executable, "-c",
'import sys,os;' 'import sys,os;'
'sys.stdout.write(os.getenv("FRUIT"))'], 'sys.stdout.write(os.getenv("FRUIT"))'],
stdout=subprocess.PIPE, stdout=subprocess.PIPE,
env=newenv) env=newenv) as p:
self.addCleanup(p.stdout.close) stdout, stderr = p.communicate()
self.assertEqual(p.stdout.read(), b"orange") self.assertEqual(stdout, b"orange")
def test_empty_env(self):
with subprocess.Popen([sys.executable, "-c",
'import os; '
'print(len(os.environ))'],
stdout=subprocess.PIPE,
env={}) as p:
stdout, stderr = p.communicate()
self.assertEqual(stdout.strip(), b"0")
def test_communicate_stdin(self): def test_communicate_stdin(self):
p = subprocess.Popen([sys.executable, "-c", p = subprocess.Popen([sys.executable, "-c",

View File

@ -25,6 +25,9 @@ Core and Builtins
Library Library
------- -------
- Issue #12383: Fix subprocess module with env={}: don't copy the environment
variables, start with an empty environment.
- Issue #11584: email.header.decode_header no longer fails if the header - Issue #11584: email.header.decode_header no longer fails if the header
passed to it is a Header object, and Header/make_header no longer fail passed to it is a Header object, and Header/make_header no longer fail
if given binary unknown-8bit input. if given binary unknown-8bit input.