From 52b496d1058a630ee60c50c3e8acc72b2df748dc Mon Sep 17 00:00:00 2001 From: Dan Date: Mon, 13 Feb 2023 10:12:31 -0500 Subject: [PATCH] Revert "more finally for better len" This reverts commit feb25c286d590d90a9dac9a9ba71ec28bf1fa380. --- .../routes/process_instances_controller.py | 1 - .../services/process_instance_processor.py | 23 +++++++++---------- .../services/service_task_service.py | 2 +- 3 files changed, 12 insertions(+), 14 deletions(-) diff --git a/spiffworkflow-backend/src/spiffworkflow_backend/routes/process_instances_controller.py b/spiffworkflow-backend/src/spiffworkflow_backend/routes/process_instances_controller.py index 40a0147f8..800c50c98 100644 --- a/spiffworkflow-backend/src/spiffworkflow_backend/routes/process_instances_controller.py +++ b/spiffworkflow-backend/src/spiffworkflow_backend/routes/process_instances_controller.py @@ -125,7 +125,6 @@ def process_instance_run( raise e except Exception as e: ErrorHandlingService().handle_error(processor, e) - # fixme: this is going to point someone to the wrong task - it's misinformation for errors in sub-processes task = processor.bpmn_process_instance.last_task raise ApiError.from_task( error_code="unknown_exception", diff --git a/spiffworkflow-backend/src/spiffworkflow_backend/services/process_instance_processor.py b/spiffworkflow-backend/src/spiffworkflow_backend/services/process_instance_processor.py index 3090aa5cd..f30ebd4b3 100644 --- a/spiffworkflow-backend/src/spiffworkflow_backend/services/process_instance_processor.py +++ b/spiffworkflow-backend/src/spiffworkflow_backend/services/process_instance_processor.py @@ -208,21 +208,20 @@ class NonTaskDataBasedScriptEngineEnvironment(BasePythonScriptEngineEnvironment) self.state.update(self.globals) self.state.update(external_methods or {}) self.state.update(context) - try: - exec(script, self.state) # noqa - finally: - # since the task data is not directly mutated when the script executes, need to determine which keys - # have been deleted from the environment and remove them from task data if present. - context_keys_to_drop = context.keys() - self.state.keys() + exec(script, self.state) # noqa - for key_to_drop in context_keys_to_drop: - context.pop(key_to_drop) + # since the task data is not directly mutated when the script executes, need to determine which keys + # have been deleted from the environment and remove them from task data if present. + context_keys_to_drop = context.keys() - self.state.keys() - self.state = self._user_defined_state(external_methods) + for key_to_drop in context_keys_to_drop: + context.pop(key_to_drop) - # the task data needs to be updated with the current state so data references can be resolved properly. - # the state will be removed later once the task is completed. - context.update(self.state) + self.state = self._user_defined_state(external_methods) + + # the task data needs to be updated with the current state so data references can be resolved properly. + # the state will be removed later once the task is completed. + context.update(self.state) def _user_defined_state( self, external_methods: Optional[Dict[str, Any]] = None diff --git a/spiffworkflow-backend/src/spiffworkflow_backend/services/service_task_service.py b/spiffworkflow-backend/src/spiffworkflow_backend/services/service_task_service.py index 2ff09af2e..982436112 100644 --- a/spiffworkflow-backend/src/spiffworkflow_backend/services/service_task_service.py +++ b/spiffworkflow-backend/src/spiffworkflow_backend/services/service_task_service.py @@ -113,7 +113,7 @@ class ServiceTaskDelegate: message = ServiceTaskDelegate.get_message_for_status( proxied_response.status_code ) - error = f"Received an unexpected response from service {name} : {message}" + error = f"Received an unexpected response from the service : {message}" if "error" in parsed_response: error += parsed_response["error"] if json_parse_error: