diff options
author | Benjamin Peterson <benjamin@python.org> | 2015-05-23 15:41:30 (GMT) |
---|---|---|
committer | Benjamin Peterson <benjamin@python.org> | 2015-05-23 15:41:30 (GMT) |
commit | 5a69420062b3d85bbe7c434e81f54f4a4e1f0e2d (patch) | |
tree | 23238e5f32b9c68c3e7f4d5acda0970732083cda | |
parent | a48db2bc8b882e887fbe8a84b31828d8491dd877 (diff) | |
parent | c4ae86e47730a4466a8d6ebae4c5531bf1dfca3b (diff) | |
download | cpython-5a69420062b3d85bbe7c434e81f54f4a4e1f0e2d.zip cpython-5a69420062b3d85bbe7c434e81f54f4a4e1f0e2d.tar.gz cpython-5a69420062b3d85bbe7c434e81f54f4a4e1f0e2d.tar.bz2 |
merge 3.4 (#22931)
-rw-r--r-- | Lib/http/cookies.py | 7 | ||||
-rw-r--r-- | Lib/test/test_http_cookies.py | 13 | ||||
-rw-r--r-- | Misc/NEWS | 2 |
3 files changed, 19 insertions, 3 deletions
diff --git a/Lib/http/cookies.py b/Lib/http/cookies.py index 26c9ac4..fda02b7 100644 --- a/Lib/http/cookies.py +++ b/Lib/http/cookies.py @@ -455,12 +455,13 @@ class Morsel(dict): # result, the parsing rules here are less strict. # -_LegalCharsPatt = r"[\w\d!#%&'~_`><@,:/\$\*\+\-\.\^\|\)\(\?\}\{\=]" +_LegalKeyChars = r"\w\d!#%&'~_`><@,:/\$\*\+\-\.\^\|\)\(\?\}\{\=" +_LegalValueChars = _LegalKeyChars + '\[\]' _CookiePattern = re.compile(r""" (?x) # This is a verbose pattern \s* # Optional whitespace at start of cookie (?P<key> # Start of group 'key' - """ + _LegalCharsPatt + r"""+? # Any word of at least one letter + [""" + _LegalKeyChars + r"""]+? # Any word of at least one letter ) # End of group 'key' ( # Optional group: there may not be a value. \s*=\s* # Equal Sign @@ -469,7 +470,7 @@ _CookiePattern = re.compile(r""" | # or \w{3},\s[\w\d\s-]{9,11}\s[\d:]{8}\sGMT # Special case for "expires" attr | # or - """ + _LegalCharsPatt + r"""* # Any word or empty string + [""" + _LegalValueChars + r"""]* # Any word or empty string ) # End of group 'val' )? # End of optional value group \s* # Any number of spaces. diff --git a/Lib/test/test_http_cookies.py b/Lib/test/test_http_cookies.py index cf0f6b9..d3e06a4 100644 --- a/Lib/test/test_http_cookies.py +++ b/Lib/test/test_http_cookies.py @@ -44,6 +44,19 @@ class CookieTests(unittest.TestCase): 'repr': "<SimpleCookie: key:term='value:term'>", 'output': 'Set-Cookie: key:term=value:term'}, + # issue22931 - Adding '[' and ']' as valid characters in cookie + # values as defined in RFC 6265 + { + 'data': 'a=b; c=[; d=r; f=h', + 'dict': {'a':'b', 'c':'[', 'd':'r', 'f':'h'}, + 'repr': "<SimpleCookie: a='b' c='[' d='r' f='h'>", + 'output': '\n'.join(( + 'Set-Cookie: a=b', + 'Set-Cookie: c=[', + 'Set-Cookie: d=r', + 'Set-Cookie: f=h' + )) + } ] for case in cases: @@ -325,6 +325,8 @@ Library lines from the code object, fixing an issue when a lambda function is used as decorator argument. Patch by Thomas Ballinger and Allison Kaptur. +- Issue #22931: Allow '[' and ']' in cookie values. + - The keywords attribute of functools.partial is now always a dictionary. - Issue #23811: Add missing newline to the PyCompileError error message. |