Use WebOb 1.8.1

The requirements/upper-constraints file was modified to allow WebOb
1.8.1 by commit 88bafa11deb9bd7595983d97ffabca338f073ba3.  This
patch simplifies some Glance code that could handle both WebOb
1.7.4 and 1.8.1 so that it now only handles the latter, and updates
the glance/requirements.txt and glance/lower-constraints.txt to
reflect that we support WebOb 1.8.1+ only.

Change-Id: I03e03013927cc5434aa0d97657d5e7efd8223ee5
Closes-bug: #1770410
This commit is contained in:
Brian Rosmaita 2018-05-20 11:41:43 -04:00
parent 9657073262
commit 9b9d0567ef
5 changed files with 33 additions and 64 deletions

View File

@ -53,12 +53,6 @@ from glance import i18n
from glance.i18n import _, _LE, _LI, _LW from glance.i18n import _, _LE, _LI, _LW
try:
from webob.acceptparse import AcceptLanguageValidHeader # noqa
USING_WEBOB_1_8 = True
except ImportError:
USING_WEBOB_1_8 = False
bind_opts = [ bind_opts = [
cfg.HostAddressOpt('bind_host', cfg.HostAddressOpt('bind_host',
default='0.0.0.0', default='0.0.0.0',
@ -1048,18 +1042,7 @@ class Request(webob.Request):
else: else:
return content_type return content_type
def _best_match_language_1_7(self): def best_match_language(self):
"""Determines best available locale from the Accept-Language header.
:returns: the best language match or None if the 'Accept-Language'
header was not available in the request.
"""
if not self.accept_language:
return None
langs = i18n.get_available_languages('glance')
return self.accept_language.best_match(langs)
def _best_match_language_1_8(self):
"""Determines best available locale from the Accept-Language header. """Determines best available locale from the Accept-Language header.
:returns: the best language match or None if the 'Accept-Language' :returns: the best language match or None if the 'Accept-Language'
@ -1076,12 +1059,6 @@ class Request(webob.Request):
best_match = None best_match = None
return best_match return best_match
def best_match_language(self):
if USING_WEBOB_1_8:
return self._best_match_language_1_8()
else:
return self._best_match_language_1_7()
def get_range_from_request(self, image_size): def get_range_from_request(self, image_size):
"""Return the `Range` in a request.""" """Return the `Range` in a request."""

View File

@ -184,31 +184,20 @@ class RequestTest(test_utils.BaseTestCase):
req = wsgi.Request.blank('/', headers={'Accept-Language': 'unknown'}) req = wsgi.Request.blank('/', headers={'Accept-Language': 'unknown'})
self.assertIsNone(req.best_match_language()) self.assertIsNone(req.best_match_language())
def test_best_match_language_unknown(self): @mock.patch.object(webob.acceptparse.AcceptLanguageValidHeader, 'lookup')
# Test that we are actually invoking language negotiation by webop def test_best_match_language_unknown(self, mock_lookup):
# Test that we are actually invoking language negotiation by WebOb
request = wsgi.Request.blank('/') request = wsgi.Request.blank('/')
accepted = 'unknown-lang' accepted = 'unknown-lang'
request.headers = {'Accept-Language': accepted} request.headers = {'Accept-Language': accepted}
# TODO(rosmaita): simplify when lower_constraints has webob >= 1.8.1 # Bug #1765748: see comment in code in the function under test
try: # to understand why this is the correct return value for the
from webob.acceptparse import AcceptLanguageValidHeader # noqa # webob 1.8.x mock
cls = webob.acceptparse.AcceptLanguageValidHeader mock_lookup.return_value = 'fake_LANG'
funcname = 'lookup'
# Bug #1765748: see comment in code in the function under test
# to understand why this is the correct return value for the
# webob 1.8.x mock
retval = 'fake_LANG'
except ImportError:
cls = webob.acceptparse.AcceptLanguage
funcname = 'best_match'
retval = None
with mock.patch.object(cls, funcname) as mocked_function: self.assertIsNone(request.best_match_language())
mocked_function.return_value = retval mock_lookup.assert_called_once()
self.assertIsNone(request.best_match_language())
mocked_function.assert_called_once()
# If Accept-Language is missing or empty, match should be None # If Accept-Language is missing or empty, match should be None
request.headers = {'Accept-Language': ''} request.headers = {'Accept-Language': ''}
@ -389,27 +378,18 @@ class ResourceTest(test_utils.BaseTestCase):
resource, request) resource, request)
self.assertEqual(message_es, str(e)) self.assertEqual(message_es, str(e))
@mock.patch.object(webob.acceptparse.AcceptLanguageValidHeader, 'lookup')
@mock.patch.object(i18n, 'translate') @mock.patch.object(i18n, 'translate')
def test_translate_exception(self, mock_translate): def test_translate_exception(self, mock_translate, mock_lookup):
# TODO(rosmaita): simplify when lower_constraints has webob >= 1.8.1 mock_translate.return_value = 'No Encontrado'
try: mock_lookup.return_value = 'de'
from webob.acceptparse import AcceptLanguageValidHeader # noqa
cls = webob.acceptparse.AcceptLanguageValidHeader
funcname = 'lookup'
except ImportError:
cls = webob.acceptparse.AcceptLanguage
funcname = 'best_match'
with mock.patch.object(cls, funcname) as mocked_function: req = wsgi.Request.blank('/tests/123')
mock_translate.return_value = 'No Encontrado' req.headers["Accept-Language"] = "de"
mocked_function.return_value = 'de'
req = wsgi.Request.blank('/tests/123') e = webob.exc.HTTPNotFound(explanation='Not Found')
req.headers["Accept-Language"] = "de" e = wsgi.translate_exception(req, e)
self.assertEqual('No Encontrado', e.explanation)
e = webob.exc.HTTPNotFound(explanation='Not Found')
e = wsgi.translate_exception(req, e)
self.assertEqual('No Encontrado', e.explanation)
def test_response_headers_encoded(self): def test_response_headers_encoded(self):
# prepare environment # prepare environment

View File

@ -138,7 +138,7 @@ unittest2==1.1.0
urllib3==1.22 urllib3==1.22
vine==1.1.4 vine==1.1.4
voluptuous==0.11.1 voluptuous==0.11.1
WebOb==1.7.1 WebOb==1.8.1
whereto===0.3.0 whereto===0.3.0
wrapt==1.10.11 wrapt==1.10.11
WSME==0.8.0 WSME==0.8.0

View File

@ -0,0 +1,12 @@
---
other:
- |
Negotiation of the 'Accept-Language' header now follows the "Lookup"
matching scheme described in `RFC 4647, section 3.4
<https://tools.ietf.org/html/rfc4647.html#section-3.4>`_. The
"Lookup" scheme is one of the algorithms suggested in `RFC 7231,
section 5.3.5
<https://tools.ietf.org/html/rfc7231.html#section-5.3.5>`_. (This is
due to a change in an underlying library, which previously used a
matching scheme that did not conform to `RFC 7231
<https://tools.ietf.org/html/rfc7231.html>`_.)

View File

@ -10,7 +10,7 @@ SQLAlchemy!=1.1.5,!=1.1.6,!=1.1.7,!=1.1.8,>=1.0.10 # MIT
eventlet!=0.18.3,!=0.20.1,>=0.18.2 # MIT eventlet!=0.18.3,!=0.20.1,>=0.18.2 # MIT
PasteDeploy>=1.5.0 # MIT PasteDeploy>=1.5.0 # MIT
Routes>=2.3.1 # MIT Routes>=2.3.1 # MIT
WebOb>=1.7.1 # MIT WebOb>=1.8.1 # MIT
sqlalchemy-migrate>=0.11.0 # Apache-2.0 sqlalchemy-migrate>=0.11.0 # Apache-2.0
sqlparse>=0.2.2 # BSD sqlparse>=0.2.2 # BSD
alembic>=0.8.10 # MIT alembic>=0.8.10 # MIT