Raise K8sResourceNotFound for all client methods

Seems like K8sClient wasn't raising K8sResourceNotFound exception on 404
from all the methods, e.g. patch. This commit makes sure that is no
longer the case and any 404 results in K8sResourceNotFound exception.

Change-Id: I23b947ef5f8c56429b5c69b73489fec19c44bd7e
Closes-Bug: 1865893
This commit is contained in:
Michał Dulko 2020-03-03 16:18:56 +01:00
parent ded6b6debc
commit fd3f4c55d7
2 changed files with 40 additions and 29 deletions

View File

@ -76,6 +76,12 @@ class K8sClient(object):
else: else:
self.verify_server = ca_crt_file self.verify_server = ca_crt_file
def _raise_from_response(self, response):
if response.status_code == requests.codes.not_found:
raise exc.K8sResourceNotFound(response.text)
if not response.ok:
raise exc.K8sClientException(response.text)
def get(self, path, json=True, headers=None): def get(self, path, json=True, headers=None):
LOG.debug("Get %(path)s", {'path': path}) LOG.debug("Get %(path)s", {'path': path})
url = self._base_url + path url = self._base_url + path
@ -87,10 +93,7 @@ class K8sClient(object):
response = self.session.get(url, cert=self.cert, response = self.session.get(url, cert=self.cert,
verify=self.verify_server, verify=self.verify_server,
headers=header) headers=header)
if response.status_code == requests.codes.not_found: self._raise_from_response(response)
raise exc.K8sResourceNotFound(response.text)
if not response.ok:
raise exc.K8sClientException(response.text)
result = response.json() if json else response.text result = response.json() if json else response.text
return result return result
@ -113,9 +116,8 @@ class K8sClient(object):
response = self.session.patch(url, json={field: data}, response = self.session.patch(url, json={field: data},
headers=header, cert=self.cert, headers=header, cert=self.cert,
verify=self.verify_server) verify=self.verify_server)
if response.ok: self._raise_from_response(response)
return response.json().get('status') return response.json().get('status')
raise exc.K8sClientException(response.text)
def patch_crd(self, field, path, data): def patch_crd(self, field, path, data):
content_type = 'application/json-patch+json' content_type = 'application/json-patch+json'
@ -132,9 +134,8 @@ class K8sClient(object):
response = self.session.patch(url, data=jsonutils.dumps(data), response = self.session.patch(url, data=jsonutils.dumps(data),
headers=header, cert=self.cert, headers=header, cert=self.cert,
verify=self.verify_server) verify=self.verify_server)
if response.ok: self._raise_from_response(response)
return response.json().get('status') return response.json().get('status')
raise exc.K8sClientException(response.text)
def patch_node_annotations(self, node, annotation_name, value): def patch_node_annotations(self, node, annotation_name, value):
content_type = 'application/json-patch+json' content_type = 'application/json-patch+json'
@ -149,9 +150,8 @@ class K8sClient(object):
response = self.session.patch(url, data=jsonutils.dumps(data), response = self.session.patch(url, data=jsonutils.dumps(data),
headers=header, cert=self.cert, headers=header, cert=self.cert,
verify=self.verify_server) verify=self.verify_server)
if response.ok: self._raise_from_response(response)
return response.json().get('status') return response.json().get('status')
raise exc.K8sClientException(response.text)
def remove_node_annotations(self, node, annotation_name): def remove_node_annotations(self, node, annotation_name):
content_type = 'application/json-patch+json' content_type = 'application/json-patch+json'
@ -164,9 +164,8 @@ class K8sClient(object):
response = self.session.patch(url, data=jsonutils.dumps(data), response = self.session.patch(url, data=jsonutils.dumps(data),
headers=header, cert=self.cert, headers=header, cert=self.cert,
verify=self.verify_server) verify=self.verify_server)
if response.ok: self._raise_from_response(response)
return response.json().get('status') return response.json().get('status')
raise exc.K8sClientException(response.text)
def post(self, path, body): def post(self, path, body):
LOG.debug("Post %(path)s: %(body)s", {'path': path, 'body': body}) LOG.debug("Post %(path)s: %(body)s", {'path': path, 'body': body})
@ -177,9 +176,8 @@ class K8sClient(object):
response = self.session.post(url, json=body, cert=self.cert, response = self.session.post(url, json=body, cert=self.cert,
verify=self.verify_server, headers=header) verify=self.verify_server, headers=header)
if response.ok: self._raise_from_response(response)
return response.json() return response.json()
raise exc.K8sClientException(response)
def delete(self, path): def delete(self, path):
LOG.debug("Delete %(path)s", {'path': path}) LOG.debug("Delete %(path)s", {'path': path})
@ -191,12 +189,8 @@ class K8sClient(object):
response = self.session.delete(url, cert=self.cert, response = self.session.delete(url, cert=self.cert,
verify=self.verify_server, verify=self.verify_server,
headers=header) headers=header)
if response.ok: self._raise_from_response(response)
return response.json() return response.json()
else:
if response.status_code == requests.codes.not_found:
raise exc.K8sResourceNotFound(response.text)
raise exc.K8sClientException(response)
def annotate(self, path, annotations, resource_version=None): def annotate(self, path, annotations, resource_version=None):
"""Pushes a resource annotation to the K8s API resource """Pushes a resource annotation to the K8s API resource
@ -245,10 +239,7 @@ class K8sClient(object):
% {'headers': response.headers, % {'headers': response.headers,
'content': response.content, 'text': response.text}) 'content': response.content, 'text': response.text})
if response.status_code == requests.codes.not_found: self._raise_from_response(response)
raise exc.K8sResourceNotFound(response.text)
else:
raise exc.K8sClientException(response.text)
def watch(self, path): def watch(self, path):
url = self._base_url + path url = self._base_url + path

View File

@ -434,3 +434,23 @@ class TestK8sClient(test_base.TestCase):
self.assertRaises(exc.K8sClientException, self.assertRaises(exc.K8sClientException,
self.client.delete, path) self.client.delete, path)
def test__raise_from_response(self):
m_resp = mock.MagicMock()
m_resp.ok = True
m_resp.status_code = 202
self.client._raise_from_response(m_resp)
def test__raise_from_response_404(self):
m_resp = mock.MagicMock()
m_resp.ok = False
m_resp.status_code = 404
self.assertRaises(exc.K8sResourceNotFound,
self.client._raise_from_response, m_resp)
def test__raise_from_response_500(self):
m_resp = mock.MagicMock()
m_resp.ok = False
m_resp.status_code = 500
self.assertRaises(exc.K8sClientException,
self.client._raise_from_response, m_resp)