]> granicus.if.org Git - python/commitdiff
Issue #4387: binascii now refuses to accept str as binary input.
authorMartin v. Löwis <martin@v.loewis.de>
Tue, 2 Dec 2008 06:00:15 +0000 (06:00 +0000)
committerMartin v. Löwis <martin@v.loewis.de>
Tue, 2 Dec 2008 06:00:15 +0000 (06:00 +0000)
Lib/email/test/test_email.py
Lib/test/test_binascii.py
Lib/test/test_descr.py
Lib/test/test_zlib.py
Misc/NEWS
Modules/binascii.c

index 9639d30a2678315861d6aaa4b9ea23d0dbe5877a..8857e4234808a46e48dee3367d97c62940599610 100644 (file)
@@ -2279,7 +2279,7 @@ Foo
         eq(charsets[0], 'utf-8')
         charset = Charset(charsets[0])
         eq(charset.get_body_encoding(), 'base64')
-        msg.set_payload('hello world', charset=charset)
+        msg.set_payload(b'hello world', charset=charset)
         eq(msg.get_payload(), 'aGVsbG8gd29ybGQ=\n')
         eq(msg.get_payload(decode=True), b'hello world')
         eq(msg['content-transfer-encoding'], 'base64')
@@ -2539,7 +2539,7 @@ class TestBase64(unittest.TestCase):
     def test_len(self):
         eq = self.assertEqual
         eq(base64mime.header_length('hello'),
-           len(base64mime.body_encode('hello', eol='')))
+           len(base64mime.body_encode(b'hello', eol='')))
         for size in range(15):
             if   size == 0 : bsize = 0
             elif size <= 3 : bsize = 4
@@ -2556,19 +2556,19 @@ class TestBase64(unittest.TestCase):
 
     def test_encode(self):
         eq = self.assertEqual
-        eq(base64mime.body_encode(''), '')
-        eq(base64mime.body_encode('hello'), 'aGVsbG8=\n')
+        eq(base64mime.body_encode(b''), b'')
+        eq(base64mime.body_encode(b'hello'), 'aGVsbG8=\n')
         # Test the binary flag
-        eq(base64mime.body_encode('hello\n'), 'aGVsbG8K\n')
+        eq(base64mime.body_encode(b'hello\n'), 'aGVsbG8K\n')
         # Test the maxlinelen arg
-        eq(base64mime.body_encode('xxxx ' * 20, maxlinelen=40), """\
+        eq(base64mime.body_encode(b'xxxx ' * 20, maxlinelen=40), """\
 eHh4eCB4eHh4IHh4eHggeHh4eCB4eHh4IHh4eHgg
 eHh4eCB4eHh4IHh4eHggeHh4eCB4eHh4IHh4eHgg
 eHh4eCB4eHh4IHh4eHggeHh4eCB4eHh4IHh4eHgg
 eHh4eCB4eHh4IA==
 """)
         # Test the eol argument
-        eq(base64mime.body_encode('xxxx ' * 20, maxlinelen=40, eol='\r\n'),
+        eq(base64mime.body_encode(b'xxxx ' * 20, maxlinelen=40, eol='\r\n'),
            """\
 eHh4eCB4eHh4IHh4eHggeHh4eCB4eHh4IHh4eHgg\r
 eHh4eCB4eHh4IHh4eHggeHh4eCB4eHh4IHh4eHgg\r
@@ -2734,7 +2734,7 @@ class TestCharset(unittest.TestCase):
         eq('hello w=F6rld', c.body_encode('hello w\xf6rld'))
         # Try a charset with Base64 body encoding
         c = Charset('utf-8')
-        eq('aGVsbG8gd29ybGQ=\n', c.body_encode('hello world'))
+        eq('aGVsbG8gd29ybGQ=\n', c.body_encode(b'hello world'))
         # Try a charset with None body encoding
         c = Charset('us-ascii')
         eq('hello world', c.body_encode('hello world'))
index 76a76b247f076facb7730043d029467c1bb81712..d4ab6bf67bc772ac2acf92a95ddfb62a234fcebe 100755 (executable)
@@ -121,7 +121,7 @@ class BinASCIITest(unittest.TestCase):
         self.assertRaises(binascii.Error, binascii.a2b_hex, t[:-1])
         self.assertRaises(binascii.Error, binascii.a2b_hex, t[:-1] + b'q')
 
-        self.assertEqual(binascii.hexlify('a'), b'61')
+        self.assertEqual(binascii.hexlify(b'a'), b'61')
 
     def test_qp(self):
         # A test for SF bug 534347 (segfaults without the proper fix)
@@ -166,7 +166,15 @@ class BinASCIITest(unittest.TestCase):
                 f(b'')
             except SystemError as err:
                 self.fail("%s(b'') raises SystemError: %s" % (n, err))
-        binascii.crc_hqx('', 0)
+        binascii.crc_hqx(b'', 0)
+
+    def test_no_binary_strings(self):
+        # b2a_ must not accept strings
+        for f in (binascii.b2a_uu, binascii.b2a_base64,
+                  binascii.b2a_hqx, binascii.b2a_qp,
+                  binascii.hexlify, binascii.rlecode_hqx,
+                  binascii.crc_hqx, binascii.crc32):
+            self.assertRaises(TypeError, f, "test")
 
 def test_main():
     support.run_unittest(BinASCIITest)
index fa3e0c3b916505f5754fc3222e629f6d90e2a195..102074038e8dbc4d1b89015cc8c5640e2337affb 100644 (file)
@@ -3097,22 +3097,14 @@ order (MRO) for bases """
         import binascii
         # SF bug [#470040] ParseTuple t# vs subclasses.
 
-        class MyStr(str):
+        class MyBytes(bytes):
             pass
-        base = 'abc'
-        m = MyStr(base)
+        base = b'abc'
+        m = MyBytes(base)
         # b2a_hex uses the buffer interface to get its argument's value, via
         # PyArg_ParseTuple 't#' code.
         self.assertEqual(binascii.b2a_hex(m), binascii.b2a_hex(base))
 
-        # It's not clear that unicode will continue to support the character
-        # buffer interface, and this test will fail if that's taken away.
-        class MyUni(str):
-            pass
-        base = 'abc'
-        m = MyUni(base)
-        self.assertEqual(binascii.b2a_hex(m), binascii.b2a_hex(base))
-
         class MyInt(int):
             pass
         m = MyInt(42)
@@ -3129,7 +3121,7 @@ order (MRO) for bases """
 
         class octetstring(str):
             def __str__(self):
-                return binascii.b2a_hex(self).decode("ascii")
+                return binascii.b2a_hex(self.encode('ascii')).decode("ascii")
             def __repr__(self):
                 return self + " repr"
 
index f52aa5e03b169e72f45665de3c142bdca85941d8..99c8ddac7151c250d4c9364781e2a869f10eae0b 100644 (file)
@@ -48,11 +48,11 @@ class ChecksumTestCase(unittest.TestCase):
         self.assertEqual(zlib.adler32('spam'), 72286642)
 
     def test_same_as_binascii_crc32(self):
-        foo = 'abcdefghijklmnop'
+        foo = b'abcdefghijklmnop'
         crc = 2486878355
         self.assertEqual(binascii.crc32(foo), crc)
         self.assertEqual(zlib.crc32(foo), crc)
-        self.assertEqual(binascii.crc32('spam'), zlib.crc32('spam'))
+        self.assertEqual(binascii.crc32(b'spam'), zlib.crc32(b'spam'))
 
 
 
index 723c71f93d2737854ee0e6c1c5f06ce87a92f403..a8565c9d49ef12d01040be70af62df954376b57a 100644 (file)
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -24,6 +24,8 @@ Core and Builtins
 Library
 -------
 
+- Issue #4387: binascii now refuses to accept str as binary input.
+
 - Issue #4073: Add 2to3 support to build_scripts, refactor that support
   in build_py.
 
index c6e03620793245888b12b8ff73b18e6eae6a0d03..52bd6dcc11eb3e2242f42d37cbdb2ea381270f66 100644 (file)
@@ -282,7 +282,7 @@ binascii_b2a_uu(PyObject *self, PyObject *args)
        PyObject *rv;
        Py_ssize_t bin_len;
 
-       if ( !PyArg_ParseTuple(args, "s*:b2a_uu", &pbin) )
+       if ( !PyArg_ParseTuple(args, "y*:b2a_uu", &pbin) )
                return NULL;
        bin_data = pbin.buf;
        bin_len = pbin.len;
@@ -478,7 +478,7 @@ binascii_b2a_base64(PyObject *self, PyObject *args)
        PyObject *rv;
        Py_ssize_t bin_len;
 
-       if ( !PyArg_ParseTuple(args, "s*:b2a_base64", &pbuf) )
+       if ( !PyArg_ParseTuple(args, "y*:b2a_base64", &pbuf) )
                return NULL;
        bin_data = pbuf.buf;
        bin_len = pbuf.len;
@@ -618,7 +618,7 @@ binascii_rlecode_hqx(PyObject *self, PyObject *args)
        unsigned char ch;
        Py_ssize_t in, inend, len;
 
-       if ( !PyArg_ParseTuple(args, "s*:rlecode_hqx", &pbuf) )
+       if ( !PyArg_ParseTuple(args, "y*:rlecode_hqx", &pbuf) )
                return NULL;
        in_data = pbuf.buf;
        len = pbuf.len;
@@ -684,7 +684,7 @@ binascii_b2a_hqx(PyObject *self, PyObject *args)
        PyObject *rv;
        Py_ssize_t len;
 
-       if ( !PyArg_ParseTuple(args, "s*:b2a_hqx", &pbin) )
+       if ( !PyArg_ParseTuple(args, "y*:b2a_hqx", &pbin) )
                return NULL;
        bin_data = pbin.buf;
        len = pbin.len;
@@ -856,7 +856,7 @@ binascii_crc_hqx(PyObject *self, PyObject *args)
        unsigned int crc;
        Py_ssize_t len;
 
-       if ( !PyArg_ParseTuple(args, "s*i:crc_hqx", &pin, &crc) )
+       if ( !PyArg_ParseTuple(args, "y*i:crc_hqx", &pin, &crc) )
                return NULL;
        bin_data = pin.buf;
        len = pin.len;
@@ -883,7 +883,7 @@ binascii_crc32(PyObject *self, PyObject *args)
     Py_ssize_t len;
     int signed_val;
 
-    if (!PyArg_ParseTuple(args, "s*|I:crc32", &pbuf, &crc32val))
+    if (!PyArg_ParseTuple(args, "y*|I:crc32", &pbuf, &crc32val))
         return NULL;
     buf = (Byte*)pbuf.buf;
     len = pbuf.len;
@@ -1047,7 +1047,7 @@ binascii_hexlify(PyObject *self, PyObject *args)
        char* retbuf;
        Py_ssize_t i, j;
 
-       if (!PyArg_ParseTuple(args, "s*:b2a_hex", &parg))
+       if (!PyArg_ParseTuple(args, "y*:b2a_hex", &parg))
                return NULL;
        argbuf = parg.buf;
        arglen = parg.len;
@@ -1300,7 +1300,7 @@ binascii_b2a_qp (PyObject *self, PyObject *args, PyObject *kwargs)
        int crlf = 0;
        unsigned char *p;
 
-       if (!PyArg_ParseTupleAndKeywords(args, kwargs, "s*|iii", kwlist, &pdata,
+       if (!PyArg_ParseTupleAndKeywords(args, kwargs, "y*|iii", kwlist, &pdata,
              &quotetabs, &istext, &header))
                return NULL;
        data = pdata.buf;