]> granicus.if.org Git - python/commitdiff
#6118: dont ignore encoding arguments for arguments with spaces in quote_plus().
authorGeorg Brandl <georg@python.org>
Tue, 26 May 2009 18:31:11 +0000 (18:31 +0000)
committerGeorg Brandl <georg@python.org>
Tue, 26 May 2009 18:31:11 +0000 (18:31 +0000)
Lib/test/test_urllib.py
Lib/urllib/parse.py
Misc/NEWS

index da6bc2d48868667785bddfb5c582e872b80cc643..ba742afc148efff2b14562b5130e866a2b116b15 100644 (file)
@@ -510,6 +510,21 @@ class QuotingTests(unittest.TestCase):
         self.assertEqual(expect, result,
                          "using quote(): %r != %r" % (expect, result))
 
+    def test_quote_plus_with_unicode(self):
+        # Encoding (latin-1) test for quote_plus
+        given = "\xa2\xd8 \xff"
+        expect = "%A2%D8+%FF"
+        result = urllib.parse.quote_plus(given, encoding="latin-1")
+        self.assertEqual(expect, result,
+                         "using quote_plus(): %r != %r" % (expect, result))
+        # Errors test for quote_plus
+        given = "ab\u6f22\u5b57 cd"
+        expect = "ab%3F%3F+cd"
+        result = urllib.parse.quote_plus(given, encoding="latin-1",
+                                         errors="replace")
+        self.assertEqual(expect, result,
+                         "using quote_plus(): %r != %r" % (expect, result))
+
 class UnquotingTests(unittest.TestCase):
     """Tests for unquote() and unquote_plus()
 
index 903368329bcaba4a0b61fd0cdec900b6add1ef22..726e85fb89e6126de79f782d1993ee16f7e4297f 100644 (file)
@@ -488,7 +488,7 @@ def quote_plus(string, safe='', encoding=None, errors=None):
         space = ' '
     else:
         space = b' '
-    string = quote(string, safe + space)
+    string = quote(string, safe + space, encoding, errors)
     return string.replace(' ', '+')
 
 def quote_from_bytes(bs, safe='/'):
index 91b5dfcf4c7b42d5ca8ff950f551446576ec7970..e8e2e5508729f7bf85bd9f2755ca9f7c5de2f15a 100644 (file)
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -34,6 +34,9 @@ Core and Builtins
 Library
 -------
 
+- Issue #6118: urllib.parse.quote_plus ignored the encoding and errors
+  arguments for strings with a space in them.
+
 - In unittest, using a skipping decorator on a class is now equivalent to
   skipping every test on the class.  The ClassTestSuite class has been removed.