mirror of
https://github.com/python/cpython.git
synced 2024-11-24 10:24:35 +08:00
Close #12383: Fix subprocess module with env={}: don't copy the environment
variables, start with an empty environment.
This commit is contained in:
parent
b7149cad04
commit
f1512a2967
@ -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:
|
||||||
|
@ -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",
|
||||||
|
@ -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.
|
||||||
|
Loading…
Reference in New Issue
Block a user