- result, detailed_status = await self._ns_execute_primitive(
- self._look_for_deployed_vca(nsr_deployed["VCA"],
- member_vnf_index=vnf_index,
- vdu_id=vdu_id,
- vdu_name=vdu_name,
- vdu_count_index=vdu_count_index),
- primitive=primitive,
- primitive_params=self._map_primitive_params(config_primitive_desc, primitive_params, desc_params))
-
- db_nslcmop_update["detailed-status"] = nslcmop_operation_state_detail = detailed_status
- db_nslcmop_update["operationState"] = nslcmop_operation_state = result
- db_nslcmop_update["statusEnteredTime"] = time()
- self.logger.debug(logging_text + " task Done with result {} {}".format(result, detailed_status))
+ if kdu_name and primitive in ("upgrade", "rollback", "status"):
+ # kdur and desc_params already set from before
+ if primitive_params:
+ desc_params.update(primitive_params)
+ # TODO Check if we will need something at vnf level
+ for index, kdu in enumerate(get_iterable(nsr_deployed, "K8s")):
+ if kdu_name == kdu["kdu-name"] and kdu["member-vnf-index"] == vnf_index:
+ break
+ else:
+ raise LcmException("KDU '{}' for vnf '{}' not deployed".format(kdu_name, vnf_index))
+
+ if kdu.get("k8scluster-type") not in self.k8scluster_map:
+ msg = "unknown k8scluster-type '{}'".format(kdu.get("k8scluster-type"))
+ raise LcmException(msg)
+
+ db_dict = {"collection": "nsrs",
+ "filter": {"_id": nsr_id},
+ "path": "_admin.deployed.K8s.{}".format(index)}
+ self.logger.debug(logging_text + "Exec k8s {} on {}.{}".format(primitive, vnf_index, kdu_name))
+ step = "Executing kdu {}".format(primitive)
+ if primitive == "upgrade":
+ if desc_params.get("kdu_model"):
+ kdu_model = desc_params.get("kdu_model")
+ del desc_params["kdu_model"]
+ else:
+ kdu_model = kdu.get("kdu-model")
+ parts = kdu_model.split(sep=":")
+ if len(parts) == 2:
+ kdu_model = parts[0]
+
+ detailed_status = await asyncio.wait_for(
+ self.k8scluster_map[kdu["k8scluster-type"]].upgrade(
+ cluster_uuid=kdu.get("k8scluster-uuid"),
+ kdu_instance=kdu.get("kdu-instance"),
+ atomic=True, kdu_model=kdu_model,
+ params=desc_params, db_dict=db_dict,
+ timeout=timeout_ns_action),
+ timeout=timeout_ns_action + 10)
+ self.logger.debug(logging_text + " Upgrade of kdu {} done".format(detailed_status))
+ elif primitive == "rollback":
+ detailed_status = await asyncio.wait_for(
+ self.k8scluster_map[kdu["k8scluster-type"]].rollback(
+ cluster_uuid=kdu.get("k8scluster-uuid"),
+ kdu_instance=kdu.get("kdu-instance"),
+ db_dict=db_dict),
+ timeout=timeout_ns_action)
+ elif primitive == "status":
+ detailed_status = await asyncio.wait_for(
+ self.k8scluster_map[kdu["k8scluster-type"]].status_kdu(
+ cluster_uuid=kdu.get("k8scluster-uuid"),
+ kdu_instance=kdu.get("kdu-instance")),
+ timeout=timeout_ns_action)
+
+ if detailed_status:
+ nslcmop_operation_state = 'COMPLETED'
+ else:
+ detailed_status = ''
+ nslcmop_operation_state = 'FAILED'
+
+ else:
+ nslcmop_operation_state, detailed_status = await self._ns_execute_primitive(
+ self._look_for_deployed_vca(nsr_deployed["VCA"],
+ member_vnf_index=vnf_index,
+ vdu_id=vdu_id,
+ vdu_count_index=vdu_count_index),
+ primitive=primitive,
+ primitive_params=self._map_primitive_params(config_primitive_desc, primitive_params, desc_params),
+ timeout=timeout_ns_action)
+
+ db_nslcmop_update["detailed-status"] = detailed_status
+ error_description_nslcmop = detailed_status if nslcmop_operation_state == "FAILED" else ""
+ self.logger.debug(logging_text + " task Done with result {} {}".format(nslcmop_operation_state,
+ detailed_status))