From f73f608d9506642579773d0ba969bf96a1871f32 Mon Sep 17 00:00:00 2001 From: Toni Jones Date: Mon, 2 Mar 2020 18:03:31 -0600 Subject: mpm: rpc: Use contextmanager for claim timeouts Modify the RPC claim timeout mechanism to use a contextmanager helper function when enabling/disabling timeouts. --- mpm/python/usrp_mpm/rpc_server.py | 71 +++++++++++++++++++++------------------ 1 file changed, 38 insertions(+), 33 deletions(-) (limited to 'mpm/python/usrp_mpm') diff --git a/mpm/python/usrp_mpm/rpc_server.py b/mpm/python/usrp_mpm/rpc_server.py index 1dc9d7065..667058bd2 100644 --- a/mpm/python/usrp_mpm/rpc_server.py +++ b/mpm/python/usrp_mpm/rpc_server.py @@ -23,6 +23,7 @@ monkey.patch_all() from builtins import str, bytes from builtins import range from six import iteritems +from contextlib import contextmanager from mprpc import RPCServer from usrp_mpm.mpmlog import get_main_logger from usrp_mpm.mpmutils import to_binary_str @@ -380,6 +381,14 @@ class MPMServer(RPCServer): self._timer.kill() self._timer = spawn_later(self._timeout_interval, self._timeout_event) + @contextmanager + def _timeout_disabler(self): + self._disable_timeouts = True + try: + yield self + finally: + self._disable_timeouts = False + ########################################################################### # Status queries ########################################################################### @@ -488,8 +497,6 @@ class MPMServer(RPCServer): :param file_metadata_l: List of dictionary of strings containing metadata :param data_l: List of binary string with the file contents to be written """ - # Stop the timer, update_component can take some time: - self._disable_timeouts = True # Check the claimed status if not self._check_token_valid(token): self._last_error =\ @@ -498,39 +505,37 @@ class MPMServer(RPCServer): ) self.log.error(self._last_error) raise RuntimeError("Attempt to update component without valid claim.") - result = self.periph_manager.update_component(file_metadata_l, data_l) - if not result: - component_ids = [metadata['id'] for metadata in file_metadata_l] - raise RuntimeError("Failed to update components: {}".format(component_ids)) - - # Check if we need to reset the peripheral manager - reset_now = False - for metadata, data in zip(file_metadata_l, data_l): - # Make sure the component is in the updateable_components - component_id = metadata['id'] - if component_id in self.periph_manager.updateable_components: - # Check if that updating that component means the PM should be reset - if self.periph_manager.updateable_components[component_id]['reset']: - reset_now = True - else: - self.log.debug("ID {} not in updateable components ({})".format( - component_id, self.periph_manager.updateable_components)) + with self._timeout_disabler(): + result = self.periph_manager.update_component(file_metadata_l, data_l) + if not result: + component_ids = [metadata['id'] for metadata in file_metadata_l] + raise RuntimeError("Failed to update components: {}".format(component_ids)) + + # Check if we need to reset the peripheral manager + reset_now = False + for metadata, data in zip(file_metadata_l, data_l): + # Make sure the component is in the updateable_components + component_id = metadata['id'] + if component_id in self.periph_manager.updateable_components: + # Check if that updating that component means the PM should be reset + if self.periph_manager.updateable_components[component_id]['reset']: + reset_now = True + else: + self.log.debug("ID {} not in updateable components ({})".format( + component_id, self.periph_manager.updateable_components)) - try: - self.log.trace("Reset after updating component? {}".format(reset_now)) - if reset_now: - self.reset_mgr() - self.log.debug("Reset the periph manager") - except Exception as ex: - self.log.error( - "Error in update_component while resetting: {}".format( - ex - )) - self._last_error = str(ex) + try: + self.log.trace("Reset after updating component? {}".format(reset_now)) + if reset_now: + self.reset_mgr() + self.log.debug("Reset the periph manager") + except Exception as ex: + self.log.error( + "Error in update_component while resetting: {}".format( + ex + )) + self._last_error = str(ex) - # Re-enable timeouts before we reset the timer, so the MPM session can - # timeout if something goes wrong - self._disable_timeouts = False self.log.debug("End of update_component") self._reset_timer() -- cgit v1.2.3