diff options
author | ReemMahmoud <rfawzy.ext@orange.com> | 2018-03-22 12:06:48 +0200 |
---|---|---|
committer | sgdt6900 <rhanafy.ext@orange.com> | 2018-03-26 16:28:53 +0200 |
commit | 7cf97412a3e8059c4ddd0a471bc3095a7b5a266b (patch) | |
tree | 389c4b9c5587d09699e7e92d1e1d89b0d7b3fe5e /moon_orchestrator/moon_orchestrator | |
parent | 6d2dbd0af7da445b39bbb7e16a36260268c685cd (diff) |
Add more tests and fix bug in moon_orchestrator
adding more validation
adding more test cases covering pods, slaves
applying comments mentioned
Change-Id: I7e58f184a3f216fc3740097244a5538c184bd940
Signed-off-by: ReemMahmoud <rfawzy.ext@orange.com>
Diffstat (limited to 'moon_orchestrator/moon_orchestrator')
-rw-r--r-- | moon_orchestrator/moon_orchestrator/api/pods.py | 38 | ||||
-rw-r--r-- | moon_orchestrator/moon_orchestrator/drivers.py | 28 |
2 files changed, 35 insertions, 31 deletions
diff --git a/moon_orchestrator/moon_orchestrator/api/pods.py b/moon_orchestrator/moon_orchestrator/api/pods.py index 3a01c3a9..389fa5b0 100644 --- a/moon_orchestrator/moon_orchestrator/api/pods.py +++ b/moon_orchestrator/moon_orchestrator/api/pods.py @@ -52,27 +52,29 @@ class Pods(Resource): for _pod_key, _pod_values in self.driver.get_pods().items(): pods[_pod_key] = [] for _pod_value in _pod_values: - if _pod_value['namespace'] != "moon": + if "namespace" in _pod_value and _pod_value['namespace'] != "moon": continue pods[_pod_key].append(_pod_value) return {"pods": pods} except Exception as e: return {"result": False, "message": str(e)}, 500 - def __get_pod_with_keystone_pid(self, keystone_pid): + def __validate_pod_with_keystone_pid(self, keystone_pid): for pod_key, pod_values in self.driver.get_pods().items(): - if pod_values[0]['keystone_project_id'] == keystone_pid: + if pod_values and "keystone_project_id" in pod_values[0] \ + and pod_values[0]['keystone_project_id'] == keystone_pid: return True - def __get_wrapper(self, slave_name): + def __is_slave_exist(self, slave_name): for slave in self.driver.get_slaves(): - if slave_name == slave["name"] \ - and slave["configured"]: + if "name" in slave and "configured" in slave \ + and slave_name == slave["name"] and slave["configured"]: return True def __get_slave_names(self): for slave in self.driver.get_slaves(): - yield slave["name"] + if "name" in slave : + yield slave["name"] @check_auth def post(self, uuid=None, user_id=None): @@ -98,27 +100,24 @@ class Pods(Resource): } } """ - pods = {} if "security_pipeline" in request.json: - if self.__get_pod_with_keystone_pid(request.json.get("keystone_project_id")): + if self.__validate_pod_with_keystone_pid(request.json.get("keystone_project_id")): raise exceptions.PipelineConflict + if not request.json.get("pdp_id"): + raise exceptions.PdpUnknown + if not request.json.get("security_pipeline"): + raise exceptions.PolicyUnknown self.driver.create_pipeline( request.json.get("keystone_project_id"), request.json.get("pdp_id"), request.json.get("security_pipeline"), manager_data=request.json, slave_name=request.json.get("slave_name")) - for _pod_key, _pod_values in self.driver.get_pods().items(): - pods[_pod_key] = [] - for _pod_value in _pod_values: - if _pod_value['namespace'] != "moon": - continue - pods[_pod_key].append(_pod_value) else: logger.info("------------------------------------") logger.info(list(self.__get_slave_names())) logger.info("------------------------------------") - if self.__get_wrapper(request.json.get("slave_name")): + if self.__is_slave_exist(request.json.get("slave_name")): raise exceptions.WrapperConflict if request.json.get("slave_name") not in self.__get_slave_names(): raise exceptions.SlaveNameUnknown @@ -144,8 +143,11 @@ class Pods(Resource): return {'result': True} except exceptions.PipelineUnknown: for slave in self.driver.get_slaves(): - if uuid in (slave['name'], slave["wrapper_name"]): - self.driver.delete_wrapper(name=slave["wrapper_name"]) + if "name" in slave and "wrapper_name" in slave: + if uuid in (slave['name'], slave["wrapper_name"]): + self.driver.delete_wrapper(name=slave["wrapper_name"]) + else : + raise exceptions.SlaveNameUnknown except Exception as e: return {"result": False, "message": str(e)}, 500 diff --git a/moon_orchestrator/moon_orchestrator/drivers.py b/moon_orchestrator/moon_orchestrator/drivers.py index bb0d0c2c..4519f3aa 100644 --- a/moon_orchestrator/moon_orchestrator/drivers.py +++ b/moon_orchestrator/moon_orchestrator/drivers.py @@ -203,13 +203,14 @@ class K8S(Driver): for key, value in pods.items(): # logger.info("ctx={}".format(active_context)) # logger.info("value={}".format(value)) - if active_context["name"] == value[0].get('slave_name'): - data = dict(active_context) - data["wrapper_name"] = value[0]['name'] - data["ip"] = value[0].get("ip", "NC") - data["port"] = value[0].get("external_port", "NC") - slaves.append(data) - break + if "name" in active_context and value and "name" in value[0]: + if active_context["name"] == value[0].get('slave_name'): + data = dict(active_context) + data["wrapper_name"] = value[0]['name'] + data["ip"] = value[0].get("ip", "NC") + data["port"] = value[0].get("external_port", "NC") + slaves.append(data) + break return slaves for ctx in contexts: data = dict(ctx) @@ -217,12 +218,13 @@ class K8S(Driver): for key, value in pods.items(): # logger.info("ctx={}".format(ctx)) # logger.info("value={}".format(value)) - if ctx["name"] == value[0].get('slave_name'): - data["wrapper_name"] = value[0]['name'] - data["ip"] = value[0].get("ip", "NC") - data["port"] = value[0].get("external_port", "NC") - data["configured"] = True - break + if "name" in ctx and value and "name" in value[0]: + if ctx["name"] == value[0].get('slave_name'): + data["wrapper_name"] = value[0]['name'] + data["ip"] = value[0].get("ip", "NC") + data["port"] = value[0].get("external_port", "NC") + data["configured"] = True + break slaves.append(data) return slaves |