mirror of
https://github.com/python/cpython.git
synced 2025-08-04 08:59:19 +00:00
gh-115886: Handle embedded null characters in shared memory name (GH-115887)
shm_open() and shm_unlink() now check for embedded null characters in the name and raise an error instead of silently truncating it.
This commit is contained in:
parent
5770006ffa
commit
79811ededd
3 changed files with 31 additions and 3 deletions
|
@ -3971,6 +3971,21 @@ class _TestSharedMemory(BaseTestCase):
|
|||
# test_multiprocessing_spawn, etc) in parallel.
|
||||
return prefix + str(os.getpid())
|
||||
|
||||
def test_shared_memory_name_with_embedded_null(self):
|
||||
name_tsmb = self._new_shm_name('test01_null')
|
||||
sms = shared_memory.SharedMemory(name_tsmb, create=True, size=512)
|
||||
self.addCleanup(sms.unlink)
|
||||
with self.assertRaises(ValueError):
|
||||
shared_memory.SharedMemory(name_tsmb + '\0a', create=False, size=512)
|
||||
if shared_memory._USE_POSIX:
|
||||
orig_name = sms._name
|
||||
try:
|
||||
sms._name = orig_name + '\0a'
|
||||
with self.assertRaises(ValueError):
|
||||
sms.unlink()
|
||||
finally:
|
||||
sms._name = orig_name
|
||||
|
||||
def test_shared_memory_basics(self):
|
||||
name_tsmb = self._new_shm_name('test01_tsmb')
|
||||
sms = shared_memory.SharedMemory(name_tsmb, create=True, size=512)
|
||||
|
@ -4105,7 +4120,7 @@ class _TestSharedMemory(BaseTestCase):
|
|||
self.addCleanup(shm2.unlink)
|
||||
self.assertEqual(shm2._name, names[1])
|
||||
|
||||
def test_invalid_shared_memory_cration(self):
|
||||
def test_invalid_shared_memory_creation(self):
|
||||
# Test creating a shared memory segment with negative size
|
||||
with self.assertRaises(ValueError):
|
||||
sms_invalid = shared_memory.SharedMemory(create=True, size=-1)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue