Skip to content

Commit

Permalink
Merge pull request #231 from openvstorage/0.1.x.error_codes
Browse files Browse the repository at this point in the history
Propagate error codes to cli
  • Loading branch information
sjovdnbos authored Jul 3, 2019
2 parents 0312eed + edc57f0 commit a702e75
Showing 1 changed file with 39 additions and 8 deletions.
47 changes: 39 additions & 8 deletions src/update/base.py
Original file line number Diff line number Diff line change
Expand Up @@ -122,8 +122,7 @@ def get_registration_key(cls):
:return: The complete key
:rtype: str
"""
if cls.COMPONENT is None:
raise NotImplementedError('Unable to build a registration key for an unknown component')
cls.validate_component()
return '{}_{}'.format(cls.UPDATE_KEY_BASE, cls.COMPONENT)

@staticmethod
Expand Down Expand Up @@ -188,8 +187,7 @@ def update_binaries(cls):
:return:
"""
cls.logger.info("Starting to update all binaries")
if cls.BINARIES is None:
raise NotImplementedError('Unable to update packages. Binaries are not included')
cls.validate_binaries()
all_package_names = chain.from_iterable([b[0] for b in cls.BINARIES])
for package_name in all_package_names:
cls.logger.info('Updating package {}'.format(package_name))
Expand Down Expand Up @@ -242,15 +240,30 @@ def restart_services_by_prefixes(cls, prefixes):
return restarted_services

@classmethod
def do_update(cls, node_identifier):
def do_update(cls, node_identifier, exit_code=False):
# type: (str, bool) -> None
"""
Do the update for the volumedriver update
:param node_identifier: Identifier of the node
:type node_identifier: str
:param exit_code: Exit the code on exceptions
:type exit_code: bool
"""
with cls.update_registration(node_identifier):
cls.update_binaries()
cls.restart_services()
cls.validate_component()
cls.logger.info('Starting {0} update for {1}'.format(cls.COMPONENT, node_identifier))
try:
with cls.update_registration(node_identifier):
cls.update_binaries()
cls.restart_services()
except Exception as ex:
cls.logger.exception('Exception during update of {0} for {1}'.format(cls.COMPONENT, node_identifier))
if exit_code:
if isinstance(ex, UpdateException):
exit(ex.error_code)
else:
exit(1)
else:
raise

@staticmethod
def get_local_root_client():
Expand All @@ -261,3 +274,21 @@ def get_local_root_client():
:rtype: SSHClient
"""
return SSHClient('127.0.0.1', username='root')

@classmethod
def validate_component(cls):
"""
Validate the existence of the component field
:return: None
"""
if cls.COMPONENT is None:
raise NotImplementedError('Unable to build a registration key for an unknown component')

@classmethod
def validate_binaries(cls):
"""
Validate the existence of the binaries
:return: None
"""
if cls.BINARIES is None:
raise NotImplementedError('Unable to update packages. Binaries are not included')

0 comments on commit a702e75

Please sign in to comment.