Kaydet (Commit) 9542cc6e authored tarafından Stefan Krah's avatar Stefan Krah

Issue #9265: Incorrect name passed as arg[0] when shell=True

and executable specified.
üst f4ebe2e8
...@@ -1073,6 +1073,8 @@ class Popen(object): ...@@ -1073,6 +1073,8 @@ class Popen(object):
if shell: if shell:
args = ["/bin/sh", "-c"] + args args = ["/bin/sh", "-c"] + args
if executable:
args[0] = executable
if executable is None: if executable is None:
executable = args[0] executable = args[0]
......
...@@ -750,6 +750,25 @@ class POSIXProcessTestCase(BaseTestCase): ...@@ -750,6 +750,25 @@ class POSIXProcessTestCase(BaseTestCase):
os.remove(fname) os.remove(fname)
self.assertEqual(rc, 47) self.assertEqual(rc, 47)
def test_specific_shell(self):
# Issue #9265: Incorrect name passed as arg[0].
shells = []
for prefix in ['/bin', '/usr/bin/', '/usr/local/bin']:
for name in ['bash', 'ksh']:
sh = os.path.join(prefix, name)
if os.path.isfile(sh):
shells.append(sh)
if not shells: # Will probably work for any shell but csh.
self.skipTest("bash or ksh required for this test")
sh = '/bin/sh'
if os.path.isfile(sh) and not os.path.islink(sh):
# Test will fail if /bin/sh is a symlink to csh.
shells.append(sh)
for sh in shells:
p = subprocess.Popen("echo $0", executable=sh, shell=True,
stdout=subprocess.PIPE)
self.assertEqual(p.stdout.read().strip(), bytes(sh, 'ascii'))
def _kill_process(self, method, *args): def _kill_process(self, method, *args):
# Do not inherit file handles from the parent. # Do not inherit file handles from the parent.
# It should fix failures on some platforms. # It should fix failures on some platforms.
......
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