mirror of
https://github.com/sartography/spiff-arena.git
synced 2025-01-13 02:54:27 +00:00
set process instance status to error if it cannot be initialized properly w/ burnettk
This commit is contained in:
parent
b0d6053209
commit
3112f3de3d
@ -419,6 +419,20 @@ class ProcessInstanceProcessor:
|
|||||||
# * __get_bpmn_process_instance, which takes spec and subprocesses and instantiates and returns a BpmnWorkflow
|
# * __get_bpmn_process_instance, which takes spec and subprocesses and instantiates and returns a BpmnWorkflow
|
||||||
def __init__(self, process_instance_model: ProcessInstanceModel, validate_only: bool = False) -> None:
|
def __init__(self, process_instance_model: ProcessInstanceModel, validate_only: bool = False) -> None:
|
||||||
"""Create a Workflow Processor based on the serialized information available in the process_instance model."""
|
"""Create a Workflow Processor based on the serialized information available in the process_instance model."""
|
||||||
|
with ProcessInstanceQueueService.dequeued(process_instance_model):
|
||||||
|
try:
|
||||||
|
self.setup_processor_with_process_instance(
|
||||||
|
process_instance_model=process_instance_model, validate_only=validate_only
|
||||||
|
)
|
||||||
|
except Exception as ex:
|
||||||
|
process_instance_model.status = ProcessInstanceStatus.error.value
|
||||||
|
db.session.add(process_instance_model)
|
||||||
|
db.session.commit()
|
||||||
|
raise ex
|
||||||
|
|
||||||
|
def setup_processor_with_process_instance(
|
||||||
|
self, process_instance_model: ProcessInstanceModel, validate_only: bool = False
|
||||||
|
) -> None:
|
||||||
tld = current_app.config["THREAD_LOCAL_DATA"]
|
tld = current_app.config["THREAD_LOCAL_DATA"]
|
||||||
tld.process_instance_id = process_instance_model.id
|
tld.process_instance_id = process_instance_model.id
|
||||||
|
|
||||||
|
@ -131,9 +131,6 @@ class ProcessInstanceService:
|
|||||||
continue
|
continue
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
db.session.rollback() # in case the above left the database with a bad transaction
|
db.session.rollback() # in case the above left the database with a bad transaction
|
||||||
process_instance.status = ProcessInstanceStatus.error.value
|
|
||||||
db.session.add(process_instance)
|
|
||||||
db.session.commit()
|
|
||||||
error_message = (
|
error_message = (
|
||||||
f"Error running waiting task for process_instance {process_instance.id}"
|
f"Error running waiting task for process_instance {process_instance.id}"
|
||||||
+ f"({process_instance.process_model_identifier}). {str(e)}"
|
+ f"({process_instance.process_model_identifier}). {str(e)}"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user