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:
Erickson Silva de Oliveira 2023-05-23 19:38:10 +00:00
parent c957b80b88
commit 74bb9d3bc1
2 changed files with 23 additions and 10 deletions
sysinv/sysinv/sysinv/sysinv

View File

@ -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'

View File

@ -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)