kubernetes_utils: avoid 404 error code in delete_custom_resource_definition() 75/59975/3
authorMytnyk, Volodymyr <volodymyrx.mytnyk@intel.com>
Thu, 19 Jul 2018 07:55:44 +0000 (08:55 +0100)
committerEmma Foley <emma.l.foley@intel.com>
Fri, 20 Jul 2018 14:13:24 +0000 (14:13 +0000)
JIRA: YARDSTICK-1317

Change-Id: I2dc924334199761d63dce9aebe9ce200ca0fddf8
Signed-off-by: Mytnyk, Volodymyr <volodymyrx.mytnyk@intel.com>
yardstick/common/kubernetes_utils.py
yardstick/orchestrator/kubernetes.py
yardstick/tests/unit/common/test_kubernetes_utils.py

index 35e590f..f9771a4 100644 (file)
@@ -223,14 +223,18 @@ def create_custom_resource_definition(body):
             action='create', resource='CustomResourceDefinition')
 
 
-def delete_custom_resource_definition(name):
+def delete_custom_resource_definition(name, skip_codes=None):
+    skip_codes = [] if not skip_codes else skip_codes
     api = get_extensions_v1beta_api()
     body_obj = client.V1DeleteOptions()
     try:
         api.delete_custom_resource_definition(name, body_obj)
-    except ApiException:
-        raise exceptions.KubernetesApiException(
-            action='delete', resource='CustomResourceDefinition')
+    except ApiException as e:
+        if e.status in skip_codes:
+            LOG.info(e.reason)
+        else:
+            raise exceptions.KubernetesApiException(
+                action='delete', resource='CustomResourceDefinition')
 
 
 def get_custom_resource_definition(kind):
index 9883290..7daff49 100644 (file)
@@ -315,7 +315,7 @@ class CustomResourceDefinitionObject(object):
         k8s_utils.create_custom_resource_definition(self._template)
 
     def delete(self):
-        k8s_utils.delete_custom_resource_definition(self._name)
+        k8s_utils.delete_custom_resource_definition(self._name, skip_codes=[404])
 
 
 class NetworkObject(object):
index bdc2c12..c102702 100644 (file)
@@ -121,6 +121,23 @@ class DeleteCustomResourceDefinitionTestCase(base.BaseUnitTestCase):
         mock_delete_crd.delete_custom_resource_definition.\
             assert_called_once_with('name', 'del_obj')
 
+    @mock.patch.object(client, 'V1DeleteOptions', return_value='del_obj')
+    @mock.patch.object(kubernetes_utils, 'get_extensions_v1beta_api')
+    @mock.patch.object(kubernetes_utils, 'LOG')
+    def test_execute_skip_exception(self, mock_log, mock_get_api, mock_delobj):
+        mock_delete_crd = mock.Mock()
+        mock_delete_crd.delete_custom_resource_definition.side_effect = rest.ApiException(
+            status=404)
+
+        mock_get_api.return_value = mock_delete_crd
+        kubernetes_utils.delete_custom_resource_definition('name', skip_codes=[404])
+
+        mock_delobj.assert_called_once()
+        mock_delete_crd.delete_custom_resource_definition.assert_called_once_with(
+            'name', 'del_obj')
+
+        mock_log.info.assert_called_once()
+
 
 class GetCustomResourceDefinitionTestCase(base.BaseUnitTestCase):