mirror of
https://github.com/python/cpython.git
synced 2025-08-31 05:58:33 +00:00
bpo-42146: Fix memory leak in subprocess.Popen() in case of uid/gid overflow (GH-22966)
Fix memory leak in subprocess.Popen() in case of uid/gid overflow Also add a test that would catch this leak with `--huntrleaks`. Alas, the test for `extra_groups` also exposes an inconsistency in our error reporting: we use a custom ValueError for `extra_groups`, but propagate OverflowError for `user` and `group`.
This commit is contained in:
parent
e68c67805e
commit
c0590c0033
3 changed files with 17 additions and 2 deletions
|
@ -1895,6 +1895,10 @@ class POSIXProcessTestCase(BaseTestCase):
|
|||
with self.assertRaises(ValueError):
|
||||
subprocess.check_call(ZERO_RETURN_CMD, user=-1)
|
||||
|
||||
with self.assertRaises(OverflowError):
|
||||
subprocess.check_call(ZERO_RETURN_CMD,
|
||||
cwd=os.curdir, env=os.environ, user=2**64)
|
||||
|
||||
if pwd is None and name_uid is not None:
|
||||
with self.assertRaises(ValueError):
|
||||
subprocess.check_call(ZERO_RETURN_CMD, user=name_uid)
|
||||
|
@ -1938,6 +1942,10 @@ class POSIXProcessTestCase(BaseTestCase):
|
|||
with self.assertRaises(ValueError):
|
||||
subprocess.check_call(ZERO_RETURN_CMD, group=-1)
|
||||
|
||||
with self.assertRaises(OverflowError):
|
||||
subprocess.check_call(ZERO_RETURN_CMD,
|
||||
cwd=os.curdir, env=os.environ, group=2**64)
|
||||
|
||||
if grp is None:
|
||||
with self.assertRaises(ValueError):
|
||||
subprocess.check_call(ZERO_RETURN_CMD, group=name_group)
|
||||
|
@ -1986,6 +1994,11 @@ class POSIXProcessTestCase(BaseTestCase):
|
|||
with self.assertRaises(ValueError):
|
||||
subprocess.check_call(ZERO_RETURN_CMD, extra_groups=[-1])
|
||||
|
||||
with self.assertRaises(ValueError):
|
||||
subprocess.check_call(ZERO_RETURN_CMD,
|
||||
cwd=os.curdir, env=os.environ,
|
||||
extra_groups=[2**64])
|
||||
|
||||
if grp is None:
|
||||
with self.assertRaises(ValueError):
|
||||
subprocess.check_call(ZERO_RETURN_CMD,
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue