Commit 1fba2ffc authored by Tal Einat's avatar Tal Einat Committed by Miss Islington (bot)

bpo-34736: improve error message for invalid length b64decode inputs (GH-9563)



Improvements:
1. Include the number of valid data characters in the error message.
2. Mention "number of data characters" rather than "length".


https://bugs.python.org/issue34736
parent 9df346bf
...@@ -3,6 +3,7 @@ ...@@ -3,6 +3,7 @@
import unittest import unittest
import binascii import binascii
import array import array
import re
# Note: "*_hex" functions are aliases for "(un)hexlify" # Note: "*_hex" functions are aliases for "(un)hexlify"
b2a_functions = ['b2a_base64', 'b2a_hex', 'b2a_hqx', 'b2a_qp', 'b2a_uu', b2a_functions = ['b2a_base64', 'b2a_hex', 'b2a_hqx', 'b2a_qp', 'b2a_uu',
...@@ -127,7 +128,10 @@ class BinASCIITest(unittest.TestCase): ...@@ -127,7 +128,10 @@ class BinASCIITest(unittest.TestCase):
# Test base64 with invalid number of valid characters (1 mod 4) # Test base64 with invalid number of valid characters (1 mod 4)
def assertInvalidLength(data): def assertInvalidLength(data):
with self.assertRaisesRegex(binascii.Error, r'(?i)invalid.+length'): n_data_chars = len(re.sub(br'[^A-Za-z0-9/+]', br'', data))
expected_errmsg_re = \
r'(?i)Invalid.+number of data characters.+' + str(n_data_chars)
with self.assertRaisesRegex(binascii.Error, expected_errmsg_re):
binascii.a2b_base64(self.type2test(data)) binascii.a2b_base64(self.type2test(data))
assertInvalidLength(b'a') assertInvalidLength(b'a')
......
...@@ -438,6 +438,7 @@ binascii_a2b_base64_impl(PyObject *module, Py_buffer *data) ...@@ -438,6 +438,7 @@ binascii_a2b_base64_impl(PyObject *module, Py_buffer *data)
{ {
const unsigned char *ascii_data; const unsigned char *ascii_data;
unsigned char *bin_data; unsigned char *bin_data;
unsigned char *bin_data_start;
int leftbits = 0; int leftbits = 0;
unsigned char this_ch; unsigned char this_ch;
unsigned int leftchar = 0; unsigned int leftchar = 0;
...@@ -461,6 +462,7 @@ binascii_a2b_base64_impl(PyObject *module, Py_buffer *data) ...@@ -461,6 +462,7 @@ binascii_a2b_base64_impl(PyObject *module, Py_buffer *data)
bin_data = _PyBytesWriter_Alloc(&writer, bin_len); bin_data = _PyBytesWriter_Alloc(&writer, bin_len);
if (bin_data == NULL) if (bin_data == NULL)
return NULL; return NULL;
bin_data_start = bin_data;
for( ; ascii_len > 0; ascii_len--, ascii_data++) { for( ; ascii_len > 0; ascii_len--, ascii_data++) {
this_ch = *ascii_data; this_ch = *ascii_data;
...@@ -516,9 +518,11 @@ binascii_a2b_base64_impl(PyObject *module, Py_buffer *data) ...@@ -516,9 +518,11 @@ binascii_a2b_base64_impl(PyObject *module, Py_buffer *data)
** This is an invalid length, as there is no possible input that ** This is an invalid length, as there is no possible input that
** could encoded into such a base64 string. ** could encoded into such a base64 string.
*/ */
PyErr_SetString(Error, PyErr_Format(Error,
"Invalid base64-encoded string: " "Invalid base64-encoded string: "
"length cannot be 1 more than a multiple of 4"); "number of data characters (%d) cannot be 1 more "
"than a multiple of 4",
(bin_data - bin_data_start) / 3 * 4 + 1);
} else { } else {
PyErr_SetString(Error, "Incorrect padding"); PyErr_SetString(Error, "Incorrect padding");
} }
......
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