mirror of
https://github.com/sartography/spiff-arena.git
synced 2025-01-27 01:40:48 +00:00
Provide info about keys in task data and python env
This commit is contained in:
parent
2afc19175e
commit
488abc03ea
@ -32,12 +32,17 @@ class GetDataSizes(Script):
|
||||
**kwargs: Any
|
||||
) -> Any:
|
||||
"""Run."""
|
||||
task = script_attributes_context.task
|
||||
cumulative_task_data_size = ProcessInstanceProcessor.get_task_data_size(
|
||||
task.workflow
|
||||
)
|
||||
python_env_size = ProcessInstanceProcessor.get_python_env_size(task.workflow)
|
||||
return {
|
||||
"cumulative_task_data_size": cumulative_task_data_size,
|
||||
"python_env_size": python_env_size,
|
||||
workflow = script_attributes_context.task.workflow
|
||||
task_data_size = ProcessInstanceProcessor.get_task_data_size(workflow)
|
||||
task_data_keys_by_task = {
|
||||
t.task_spec.name: sorted(t.data.keys())
|
||||
for t in ProcessInstanceProcessor.get_tasks_with_data(workflow)
|
||||
}
|
||||
python_env_size = ProcessInstanceProcessor.get_python_env_size(workflow)
|
||||
python_env_keys = workflow.script_engine.environment.user_defined_state().keys()
|
||||
return {
|
||||
"python_env_size": python_env_size,
|
||||
"python_env_keys": sorted(python_env_keys),
|
||||
"task_data_size": task_data_size,
|
||||
"task_data_keys_by_task": task_data_keys_by_task,
|
||||
}
|
||||
|
@ -1607,14 +1607,21 @@ class ProcessInstanceProcessor:
|
||||
except WorkflowTaskException as we:
|
||||
raise ApiError.from_workflow_exception("task_error", str(we), we) from we
|
||||
|
||||
@classmethod
|
||||
def get_tasks_with_data(cls, bpmn_process_instance: BpmnWorkflow) -> List[SpiffTask]:
|
||||
return [
|
||||
task
|
||||
for task in bpmn_process_instance.get_tasks(TaskState.FINISHED_MASK)
|
||||
if len(task.data) > 0
|
||||
]
|
||||
|
||||
@classmethod
|
||||
def get_task_data_size(cls, bpmn_process_instance: BpmnWorkflow) -> int:
|
||||
tasks_to_check = bpmn_process_instance.get_tasks(TaskState.FINISHED_MASK)
|
||||
task_data = [task.data for task in tasks_to_check]
|
||||
task_data_to_check = list(filter(len, task_data))
|
||||
tasks_with_data = cls.get_tasks_with_data(bpmn_process_instance)
|
||||
all_task_data = [task.data for task in tasks_with_data]
|
||||
|
||||
try:
|
||||
return len(json.dumps(task_data_to_check))
|
||||
return len(json.dumps(all_task_data))
|
||||
except Exception:
|
||||
return 0
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user