mirror of
https://github.com/python/cpython.git
synced 2025-08-09 19:38:42 +00:00
[3.12] gh-124248: Fix crash in struct when processing 0p fields (GH-124251) (#124278)
gh-124248: Fix crash in struct when processing 0p fields (GH-124251)
(cherry picked from commit 63f196090f
)
Co-authored-by: Brian Schubert <brianm.schubert@gmail.com>
This commit is contained in:
parent
6c6b044304
commit
6644cd2c1b
4 changed files with 27 additions and 4 deletions
|
@ -96,6 +96,13 @@ class StructTest(unittest.TestCase):
|
|||
('10s', b'helloworld', b'helloworld', b'helloworld', 0),
|
||||
('11s', b'helloworld', b'helloworld\0', b'helloworld\0', 1),
|
||||
('20s', b'helloworld', b'helloworld'+10*b'\0', b'helloworld'+10*b'\0', 1),
|
||||
('0p', b'helloworld', b'', b'', 1),
|
||||
('1p', b'helloworld', b'\x00', b'\x00', 1),
|
||||
('2p', b'helloworld', b'\x01h', b'\x01h', 1),
|
||||
('10p', b'helloworld', b'\x09helloworl', b'\x09helloworl', 1),
|
||||
('11p', b'helloworld', b'\x0Ahelloworld', b'\x0Ahelloworld', 0),
|
||||
('12p', b'helloworld', b'\x0Ahelloworld\0', b'\x0Ahelloworld\0', 1),
|
||||
('20p', b'helloworld', b'\x0Ahelloworld'+9*b'\0', b'\x0Ahelloworld'+9*b'\0', 1),
|
||||
('b', 7, b'\7', b'\7', 0),
|
||||
('b', -7, b'\371', b'\371', 0),
|
||||
('B', 7, b'\7', b'\7', 0),
|
||||
|
@ -339,6 +346,7 @@ class StructTest(unittest.TestCase):
|
|||
def test_p_code(self):
|
||||
# Test p ("Pascal string") code.
|
||||
for code, input, expected, expectedback in [
|
||||
('0p', b'abc', b'', b''),
|
||||
('p', b'abc', b'\x00', b''),
|
||||
('1p', b'abc', b'\x00', b''),
|
||||
('2p', b'abc', b'\x01a', b'a'),
|
||||
|
@ -580,6 +588,7 @@ class StructTest(unittest.TestCase):
|
|||
self.check_sizeof('187s', 1)
|
||||
self.check_sizeof('20p', 1)
|
||||
self.check_sizeof('0s', 1)
|
||||
self.check_sizeof('0p', 1)
|
||||
self.check_sizeof('0c', 0)
|
||||
|
||||
def test_boundary_error_message(self):
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue