Accepting request 874658 from devel:languages:python

OBS-URL: https://build.opensuse.org/request/show/874658
OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/python-yarl?expand=0&rev=16
This commit is contained in:
Richard Brown 2021-03-02 13:43:01 +00:00 committed by Git OBS Bridge
commit d3217e2a64
3 changed files with 78 additions and 2 deletions

View File

@ -1,3 +1,10 @@
-------------------------------------------------------------------
Tue Feb 23 17:02:42 UTC 2021 - Matej Cepl <mcepl@suse.com>
- Add tests_overcome_bpo42967.patch to over effects of bpo#42967,
which forbade mixing amps and semicolons in query strings as
separators.
-------------------------------------------------------------------
Sat Dec 19 10:06:48 UTC 2020 - Dirk Müller <dmueller@suse.com>

View File

@ -1,7 +1,7 @@
#
# spec file for package python-yarl
#
# Copyright (c) 2020 SUSE LLC
# Copyright (c) 2021 SUSE LLC
#
# All modifications and additions to the file contributed by third parties
# remain the property of their copyright owners, unless otherwise agreed
@ -26,6 +26,10 @@ License: Apache-2.0
Group: Development/Languages/Python
URL: https://github.com/aio-libs/yarl/
Source: https://files.pythonhosted.org/packages/source/y/yarl/yarl-%{version}.tar.gz
# PATCH-FIX-UPSTREAM tests_overcome_bpo42967.patch bsc#[0-9]+ mcepl@suse.com
# Overcome effects of bpo#42967, which forbade mixing amps and
# semicolons in query strings as separators.
Patch0: tests_overcome_bpo42967.patch
BuildRequires: %{python_module Cython}
BuildRequires: %{python_module devel}
BuildRequires: %{python_module idna >= 2.0}
@ -46,7 +50,7 @@ Requires: python-typing_extensions >= 3.7.4
The module provides a URL class for url parsing and changing.
%prep
%setup -q -n yarl-%{version}
%autosetup -p1 -n yarl-%{version}
%build
export CFLAGS="%{optflags}"

View File

@ -0,0 +1,65 @@
--- a/yarl/_url.py
+++ b/yarl/_url.py
@@ -1,4 +1,5 @@
import functools
+import inspect
import sys
import warnings
from collections.abc import Mapping, Sequence
@@ -142,7 +143,7 @@ class URL:
_PATH_UNQUOTER = _Unquoter(unsafe="+")
_QS_UNQUOTER = _Unquoter(qs=True)
- def __new__(cls, val="", *, encoded=False, strict=None):
+ def __new__(cls, val="", *, encoded=False, strict=None, separator='&'):
if strict is not None: # pragma: no cover
warnings.warn("strict parameter is ignored")
if type(val) is cls:
@@ -157,6 +158,8 @@ class URL:
else:
raise TypeError("Constructor parameter should be str")
+ cls.qs_sep = separator
+
if not encoded:
if not val[1]: # netloc
netloc = ""
@@ -551,7 +554,12 @@ class URL:
Empty value if URL has no query part.
"""
- ret = MultiDict(parse_qsl(self.raw_query_string, keep_blank_values=True))
+ if 'separator' in inspect.signature(parse_qsl).parameters:
+ qs_dict = parse_qsl(self.raw_query_string,
+ keep_blank_values=True, separator=self.qs_sep)
+ else:
+ qs_dict = parse_qsl(self.raw_query_string, keep_blank_values=True)
+ ret = MultiDict(qs_dict)
return MultiDictProxy(ret)
@property
@@ -988,7 +996,12 @@ class URL:
def update_query(self, *args, **kwargs):
"""Return a new URL with query part updated."""
s = self._get_str_query(*args, **kwargs)
- new_query = MultiDict(parse_qsl(s, keep_blank_values=True))
+ if 'separator' in inspect.signature(parse_qsl).parameters:
+ qs_dict = parse_qsl(s, keep_blank_values=True,
+ separator=self.qs_sep)
+ else:
+ qs_dict = parse_qsl(s, keep_blank_values=True)
+ new_query = MultiDict(qs_dict)
query = MultiDict(self.query)
query.update(new_query)
--- a/tests/test_url_query.py
+++ b/tests/test_url_query.py
@@ -63,7 +63,7 @@ def test_ampersand_as_value():
def test_semicolon_as_separator():
- u = URL("http://127.0.0.1/?a=1;b=2")
+ u = URL("http://127.0.0.1/?a=1;b=2", separator=';')
assert len(u.query) == 2