summaryrefslogtreecommitdiff
path: root/Lib/test/test_binascii.py
diff options
context:
space:
mode:
authorTal Einat <taleinat+github@gmail.com>2018-06-10 10:01:50 +0300
committerGitHub <noreply@github.com>2018-06-10 10:01:50 +0300
commit1b85c71a2136d3fa6a1da05b27b1fe4e4b8ee45e (patch)
tree33e452552b363273857b7499558959277171d1d7 /Lib/test/test_binascii.py
parent98a0e466cd94d4635769cfdfd397c43c07384595 (diff)
downloadcpython-git-1b85c71a2136d3fa6a1da05b27b1fe4e4b8ee45e.tar.gz
bpo-33770: improve base64 exception message for encoded inputs of invalid length (#7416)
Diffstat (limited to 'Lib/test/test_binascii.py')
-rw-r--r--Lib/test/test_binascii.py28
1 files changed, 28 insertions, 0 deletions
diff --git a/Lib/test/test_binascii.py b/Lib/test/test_binascii.py
index 0997d9432b..c5fcc1ac16 100644
--- a/Lib/test/test_binascii.py
+++ b/Lib/test/test_binascii.py
@@ -110,6 +110,34 @@ class BinASCIITest(unittest.TestCase):
# empty strings. TBD: shouldn't it raise an exception instead ?
self.assertEqual(binascii.a2b_base64(self.type2test(fillers)), b'')
+ def test_base64errors(self):
+ # Test base64 with invalid padding
+ def assertIncorrectPadding(data):
+ with self.assertRaisesRegex(binascii.Error, r'(?i)Incorrect padding'):
+ binascii.a2b_base64(self.type2test(data))
+
+ assertIncorrectPadding(b'ab')
+ assertIncorrectPadding(b'ab=')
+ assertIncorrectPadding(b'abc')
+ assertIncorrectPadding(b'abcdef')
+ assertIncorrectPadding(b'abcdef=')
+ assertIncorrectPadding(b'abcdefg')
+ assertIncorrectPadding(b'a=b=')
+ assertIncorrectPadding(b'a\nb=')
+
+ # Test base64 with invalid number of valid characters (1 mod 4)
+ def assertInvalidLength(data):
+ with self.assertRaisesRegex(binascii.Error, r'(?i)invalid.+length'):
+ binascii.a2b_base64(self.type2test(data))
+
+ assertInvalidLength(b'a')
+ assertInvalidLength(b'a=')
+ assertInvalidLength(b'a==')
+ assertInvalidLength(b'a===')
+ assertInvalidLength(b'a' * 5)
+ assertInvalidLength(b'a' * (4 * 87 + 1))
+ assertInvalidLength(b'A\tB\nC ??DE') # only 5 valid characters
+
def test_uu(self):
MAX_UU = 45
for backtick in (True, False):