Create lifecycle hook on application recovery
There was no lifecycle hook during recovery. Thus, in platform-integ-apps it was not possible to identify when this happened. To solve this, a new operation constant was created and the lifecycle hook was triggered inside _perform_app_recover(). Test Plan: PASS: When forcing recovery, it was possible to observe the lifecycle with the "recover" operation (SX/DX/Storage) Story: 2010688 Task: 48081 Change-Id: I44447ca2246a8461d98f8ea64e2e16c127c357a6 Signed-off-by: Erickson Silva de Oliveira <Erickson.SilvadeOliveira@windriver.com>
This commit is contained in:
parent
c957b80b88
commit
74bb9d3bc1
sysinv/sysinv/sysinv/sysinv
@ -1824,6 +1824,7 @@ APP_APPLY_OP = 'apply'
|
|||||||
APP_REMOVE_OP = 'remove'
|
APP_REMOVE_OP = 'remove'
|
||||||
APP_DELETE_OP = 'delete'
|
APP_DELETE_OP = 'delete'
|
||||||
APP_UPDATE_OP = 'update'
|
APP_UPDATE_OP = 'update'
|
||||||
|
APP_RECOVER_OP = 'recover'
|
||||||
APP_ROLLBACK_OP = 'rollback'
|
APP_ROLLBACK_OP = 'rollback'
|
||||||
APP_ABORT_OP = 'abort'
|
APP_ABORT_OP = 'abort'
|
||||||
APP_EVALUATE_REAPPLY_OP = 'evaluate-reapply'
|
APP_EVALUATE_REAPPLY_OP = 'evaluate-reapply'
|
||||||
|
@ -1692,7 +1692,9 @@ class AppOperator(object):
|
|||||||
with self._lock:
|
with self._lock:
|
||||||
from_app.update_app_metadata(new_metadata)
|
from_app.update_app_metadata(new_metadata)
|
||||||
|
|
||||||
def _perform_app_recover(self, old_app, new_app, fluxcd_process_required=True):
|
def _perform_app_recover(self, rpc_app, old_app, new_app,
|
||||||
|
lifecycle_hook_info_app,
|
||||||
|
fluxcd_process_required=True):
|
||||||
"""Perform application recover
|
"""Perform application recover
|
||||||
|
|
||||||
This recover method is triggered when application update failed, it cleans
|
This recover method is triggered when application update failed, it cleans
|
||||||
@ -1703,8 +1705,10 @@ class AppOperator(object):
|
|||||||
The app status will be populated to "apply-failed" if recover fails so that
|
The app status will be populated to "apply-failed" if recover fails so that
|
||||||
the user can re-apply app.
|
the user can re-apply app.
|
||||||
|
|
||||||
|
:param rpc_app: application object in the RPC request
|
||||||
:param old_app: the application object that application recovering to
|
:param old_app: the application object that application recovering to
|
||||||
:param new_app: the application object that application recovering from
|
:param new_app: the application object that application recovering from
|
||||||
|
:param lifecycle_hook_info_app: LifecycleHookInfo object
|
||||||
:param fluxcd_process_required: boolean, whether fluxcd operation is needed
|
:param fluxcd_process_required: boolean, whether fluxcd operation is needed
|
||||||
"""
|
"""
|
||||||
|
|
||||||
@ -1733,6 +1737,15 @@ class AppOperator(object):
|
|||||||
version=new_app.version,
|
version=new_app.version,
|
||||||
inactive=True)
|
inactive=True)
|
||||||
|
|
||||||
|
lifecycle_hook_info_app_recover = copy.deepcopy(lifecycle_hook_info_app)
|
||||||
|
lifecycle_hook_info_app_recover.operation = constants.APP_RECOVER_OP
|
||||||
|
|
||||||
|
lifecycle_hook_info_app_recover.lifecycle_type = constants.APP_LIFECYCLE_TYPE_RBD
|
||||||
|
self.app_lifecycle_actions(None, None, rpc_app, lifecycle_hook_info_app_recover)
|
||||||
|
|
||||||
|
lifecycle_hook_info_app_recover.lifecycle_type = constants.APP_LIFECYCLE_TYPE_RESOURCE
|
||||||
|
self.app_lifecycle_actions(None, None, rpc_app, lifecycle_hook_info_app_recover)
|
||||||
|
|
||||||
LOG.info("Recovering helm charts for Application %s (%s)..."
|
LOG.info("Recovering helm charts for Application %s (%s)..."
|
||||||
% (old_app.name, old_app.version))
|
% (old_app.name, old_app.version))
|
||||||
self._update_app_status(old_app,
|
self._update_app_status(old_app,
|
||||||
@ -2660,14 +2673,14 @@ class AppOperator(object):
|
|||||||
except exception.LifecycleSemanticCheckException as e:
|
except exception.LifecycleSemanticCheckException as e:
|
||||||
LOG.info("App {} rejected operation {} for reason: {}"
|
LOG.info("App {} rejected operation {} for reason: {}"
|
||||||
"".format(to_app.name, constants.APP_UPDATE_OP, str(e)))
|
"".format(to_app.name, constants.APP_UPDATE_OP, str(e)))
|
||||||
# lifecycle hooks not used in perform_app_recover
|
return self._perform_app_recover(to_rpc_app, from_app, to_app,
|
||||||
return self._perform_app_recover(from_app, to_app,
|
lifecycle_hook_info_app_update,
|
||||||
fluxcd_process_required=False)
|
fluxcd_process_required=False)
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
LOG.error("App {} operation {} semantic check error: {}"
|
LOG.error("App {} operation {} semantic check error: {}"
|
||||||
"".format(to_app.name, constants.APP_UPDATE_OP, str(e)))
|
"".format(to_app.name, constants.APP_UPDATE_OP, str(e)))
|
||||||
# lifecycle hooks not used in perform_app_recover
|
return self._perform_app_recover(to_rpc_app, from_app, to_app,
|
||||||
return self._perform_app_recover(from_app, to_app,
|
lifecycle_hook_info_app_update,
|
||||||
fluxcd_process_required=False)
|
fluxcd_process_required=False)
|
||||||
|
|
||||||
self.load_application_metadata_from_file(to_rpc_app)
|
self.load_application_metadata_from_file(to_rpc_app)
|
||||||
@ -2736,9 +2749,8 @@ class AppOperator(object):
|
|||||||
if do_recovery:
|
if do_recovery:
|
||||||
LOG.error("Application %s update from version %s to version "
|
LOG.error("Application %s update from version %s to version "
|
||||||
"%s aborted." % (to_app.name, from_app.version, to_app.version))
|
"%s aborted." % (to_app.name, from_app.version, to_app.version))
|
||||||
|
return self._perform_app_recover(to_rpc_app, from_app, to_app,
|
||||||
# lifecycle hooks not used in perform_app_recover
|
lifecycle_hook_info_app_update)
|
||||||
return self._perform_app_recover(from_app, to_app)
|
|
||||||
|
|
||||||
self._update_app_status(to_app, constants.APP_UPDATE_IN_PROGRESS,
|
self._update_app_status(to_app, constants.APP_UPDATE_IN_PROGRESS,
|
||||||
"cleanup application version {}".format(from_app.version))
|
"cleanup application version {}".format(from_app.version))
|
||||||
@ -2799,8 +2811,8 @@ class AppOperator(object):
|
|||||||
# ie.images download/k8s resource creation failure
|
# ie.images download/k8s resource creation failure
|
||||||
# Start recovering without trigger fluxcd process
|
# Start recovering without trigger fluxcd process
|
||||||
LOG.exception(e)
|
LOG.exception(e)
|
||||||
# lifecycle hooks not used in perform_app_recover
|
return self._perform_app_recover(to_rpc_app, from_app, to_app,
|
||||||
return self._perform_app_recover(from_app, to_app,
|
lifecycle_hook_info_app_update,
|
||||||
fluxcd_process_required=False)
|
fluxcd_process_required=False)
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
# Application update successfully(fluxcd apply/rollback)
|
# Application update successfully(fluxcd apply/rollback)
|
||||||
|
Loading…
Reference in New Issue
Block a user