Issue #7019: An attempt to unmarshal bad long data could produce

unnormalized PyLong objects; make it raise ValueError instead.
This commit is contained in:
Mark Dickinson 2009-10-03 08:15:49 +00:00
parent 7664bfe4e2
commit c3a12775e2
3 changed files with 10 additions and 1 deletions

View File

@ -262,6 +262,11 @@ class BugsTestCase(unittest.TestCase):
testString = 'abc' * size
marshal.dumps(testString)
def test_invalid_longs(self):
# Issue #7019: marshal.loads shouldn't produce unnormalized PyLongs
invalid_string = 'l\x02\x00\x00\x00\x00\x00\x00\x00'
self.assertRaises(ValueError, marshal.loads, invalid_string)
def test_main():
test_support.run_unittest(IntTestCase,

View File

@ -12,6 +12,9 @@ What's New in Python 2.6.4a1?
Core and Builtins
-----------------
- Issue #7019: Raise ValueError when unmarshalling bad long data, instead
of producing internally inconsistent Python longs.
Library
-------

View File

@ -589,7 +589,8 @@ r_object(RFILE *p)
ob->ob_size = n;
for (i = 0; i < size; i++) {
int digit = r_short(p);
if (digit < 0) {
if (digit < 0 ||
(digit == 0 && i == size-1)) {
Py_DECREF(ob);
PyErr_SetString(PyExc_ValueError,
"bad marshal data");