Merge "Check response headers for microversions"

This commit is contained in:
Jenkins 2015-11-25 12:53:49 +00:00 committed by Gerrit Code Review
commit d12d6f90cd
3 changed files with 40 additions and 1 deletions

View File

@ -30,6 +30,7 @@ if not LOG.handlers:
LOG.addHandler(logging.StreamHandler()) LOG.addHandler(logging.StreamHandler())
HEADER_NAME = "X-OpenStack-Nova-API-Version"
# key is a deprecated version and value is an alternative version. # key is a deprecated version and value is an alternative version.
DEPRECATED_VERSIONS = {"1.1": "2"} DEPRECATED_VERSIONS = {"1.1": "2"}
@ -306,7 +307,16 @@ def update_headers(headers, api_version):
"""Set 'X-OpenStack-Nova-API-Version' header if api_version is not null""" """Set 'X-OpenStack-Nova-API-Version' header if api_version is not null"""
if not api_version.is_null() and api_version.ver_minor != 0: if not api_version.is_null() and api_version.ver_minor != 0:
headers["X-OpenStack-Nova-API-Version"] = api_version.get_string() headers[HEADER_NAME] = api_version.get_string()
def check_headers(response, api_version):
"""Checks that 'X-OpenStack-Nova-API-Version' header in response."""
if api_version.ver_minor > 0 and HEADER_NAME not in response.headers:
LOG.warning(_LW(
"Your request was processed by a Nova API which does not support "
"microversions (%s header is missing from response). "
"Warning: Response may be incorrect."), HEADER_NAME)
def add_substitution(versioned_method): def add_substitution(versioned_method):

View File

@ -89,6 +89,7 @@ class SessionClient(adapter.LegacyJsonAdapter):
method, method,
raise_exc=False, raise_exc=False,
**kwargs) **kwargs)
api_versions.check_headers(resp, self.api_version)
if raise_exc and resp.status_code >= 400: if raise_exc and resp.status_code >= 400:
raise exceptions.from_response(resp, body, url, method) raise exceptions.from_response(resp, body, url, method)
@ -365,6 +366,8 @@ class HTTPClient(object):
url, url,
**kwargs) **kwargs)
api_versions.check_headers(resp, self.api_version)
self.http_log_resp(resp) self.http_log_resp(resp)
if resp.text: if resp.text:

View File

@ -145,6 +145,32 @@ class UpdateHeadersTestCase(utils.TestCase):
headers) headers)
class CheckHeadersTestCase(utils.TestCase):
def setUp(self):
super(CheckHeadersTestCase, self).setUp()
mock_log_patch = mock.patch("novaclient.api_versions.LOG")
self.mock_log = mock_log_patch.start()
self.addCleanup(mock_log_patch.stop)
def test_microversion_is_specified(self):
response = mock.MagicMock(headers={api_versions.HEADER_NAME: ""})
api_versions.check_headers(response, api_versions.APIVersion("2.2"))
self.assertFalse(self.mock_log.warning.called)
response = mock.MagicMock(headers={})
api_versions.check_headers(response, api_versions.APIVersion("2.2"))
self.assertTrue(self.mock_log.warning.called)
def test_microversion_is_not_specified(self):
response = mock.MagicMock(headers={api_versions.HEADER_NAME: ""})
api_versions.check_headers(response, api_versions.APIVersion("2.2"))
self.assertFalse(self.mock_log.warning.called)
response = mock.MagicMock(headers={})
api_versions.check_headers(response, api_versions.APIVersion("2.0"))
self.assertFalse(self.mock_log.warning.called)
class GetAPIVersionTestCase(utils.TestCase): class GetAPIVersionTestCase(utils.TestCase):
def test_get_available_client_versions(self): def test_get_available_client_versions(self):
output = api_versions.get_available_major_versions() output = api_versions.get_available_major_versions()