added debug logging when adding spiff step details w/ burnettk
This commit is contained in:
parent
9d81078ef6
commit
09a46712d4
|
@ -1,7 +1,6 @@
|
||||||
"""__init__."""
|
"""__init__."""
|
||||||
import faulthandler
|
import faulthandler
|
||||||
import os
|
import os
|
||||||
import sys
|
|
||||||
from typing import Any
|
from typing import Any
|
||||||
|
|
||||||
import connexion # type: ignore
|
import connexion # type: ignore
|
||||||
|
|
|
@ -672,14 +672,6 @@ class ProcessInstanceProcessor:
|
||||||
"end_in_seconds": end_in_seconds,
|
"end_in_seconds": end_in_seconds,
|
||||||
}
|
}
|
||||||
|
|
||||||
def spiff_step_details(
|
|
||||||
self, spiff_task: Optional[SpiffTask] = None
|
|
||||||
) -> SpiffStepDetailsModel:
|
|
||||||
"""SaveSpiffStepDetails."""
|
|
||||||
details_mapping = self.spiff_step_details_mapping(spiff_task=spiff_task)
|
|
||||||
details_model = SpiffStepDetailsModel(**details_mapping)
|
|
||||||
return details_model
|
|
||||||
|
|
||||||
def extract_metadata(self, process_model_info: ProcessModelInfo) -> None:
|
def extract_metadata(self, process_model_info: ProcessModelInfo) -> None:
|
||||||
"""Extract_metadata."""
|
"""Extract_metadata."""
|
||||||
metadata_extraction_paths = process_model_info.metadata_extraction_paths
|
metadata_extraction_paths = process_model_info.metadata_extraction_paths
|
||||||
|
@ -940,6 +932,7 @@ class ProcessInstanceProcessor:
|
||||||
)
|
)
|
||||||
db.session.add(spiff_step_detail)
|
db.session.add(spiff_step_detail)
|
||||||
db.session.commit()
|
db.session.commit()
|
||||||
|
self.log_spiff_step_details(spiff_step_detail_mapping)
|
||||||
|
|
||||||
if len(human_tasks) > 0:
|
if len(human_tasks) > 0:
|
||||||
for at in human_tasks:
|
for at in human_tasks:
|
||||||
|
@ -973,8 +966,10 @@ class ProcessInstanceProcessor:
|
||||||
"""Add a spiff step."""
|
"""Add a spiff step."""
|
||||||
if step is None:
|
if step is None:
|
||||||
step = self.spiff_step_details_mapping()
|
step = self.spiff_step_details_mapping()
|
||||||
db.session.add(SpiffStepDetailsModel(**step))
|
spiff_step_detail = SpiffStepDetailsModel(**step)
|
||||||
|
db.session.add(spiff_step_detail)
|
||||||
db.session.commit()
|
db.session.commit()
|
||||||
|
self.log_spiff_step_details(step)
|
||||||
|
|
||||||
def manual_complete_task(self, task_id: str, execute: bool) -> None:
|
def manual_complete_task(self, task_id: str, execute: bool) -> None:
|
||||||
"""Mark the task complete optionally executing it."""
|
"""Mark the task complete optionally executing it."""
|
||||||
|
@ -1257,6 +1252,7 @@ class ProcessInstanceProcessor:
|
||||||
# could consider borrowing their "cleanup all my locks when the app quits" idea as well and
|
# could consider borrowing their "cleanup all my locks when the app quits" idea as well and
|
||||||
# implement via https://docs.python.org/3/library/atexit.html
|
# implement via https://docs.python.org/3/library/atexit.html
|
||||||
def lock_process_instance(self, lock_prefix: str) -> None:
|
def lock_process_instance(self, lock_prefix: str) -> None:
|
||||||
|
current_app.config["THREAD_LOCAL_DATA"].locked_by_prefix = lock_prefix
|
||||||
locked_by = f"{lock_prefix}_{current_app.config['PROCESS_UUID']}"
|
locked_by = f"{lock_prefix}_{current_app.config['PROCESS_UUID']}"
|
||||||
current_time_in_seconds = round(time.time())
|
current_time_in_seconds = round(time.time())
|
||||||
lock_expiry_in_seconds = (
|
lock_expiry_in_seconds = (
|
||||||
|
@ -1289,6 +1285,7 @@ class ProcessInstanceProcessor:
|
||||||
)
|
)
|
||||||
|
|
||||||
def unlock_process_instance(self, lock_prefix: str) -> None:
|
def unlock_process_instance(self, lock_prefix: str) -> None:
|
||||||
|
current_app.config["THREAD_LOCAL_DATA"].locked_by_prefix = None
|
||||||
locked_by = f"{lock_prefix}_{current_app.config['PROCESS_UUID']}"
|
locked_by = f"{lock_prefix}_{current_app.config['PROCESS_UUID']}"
|
||||||
if self.process_instance_model.locked_by != locked_by:
|
if self.process_instance_model.locked_by != locked_by:
|
||||||
raise ProcessInstanceLockedBySomethingElseError(
|
raise ProcessInstanceLockedBySomethingElseError(
|
||||||
|
@ -1435,6 +1432,7 @@ class ProcessInstanceProcessor:
|
||||||
raise ApiError.from_workflow_exception("task_error", str(swe), swe) from swe
|
raise ApiError.from_workflow_exception("task_error", str(swe), swe) from swe
|
||||||
|
|
||||||
finally:
|
finally:
|
||||||
|
self.log_spiff_step_details(step_details)
|
||||||
db.session.bulk_insert_mappings(SpiffStepDetailsModel, step_details)
|
db.session.bulk_insert_mappings(SpiffStepDetailsModel, step_details)
|
||||||
spiff_logger = logging.getLogger("spiff")
|
spiff_logger = logging.getLogger("spiff")
|
||||||
for handler in spiff_logger.handlers:
|
for handler in spiff_logger.handlers:
|
||||||
|
@ -1445,6 +1443,17 @@ class ProcessInstanceProcessor:
|
||||||
if save:
|
if save:
|
||||||
self.save()
|
self.save()
|
||||||
|
|
||||||
|
# log the spiff step details so we know what is processing the process
|
||||||
|
# instance when a human task has a timer event.
|
||||||
|
def log_spiff_step_details(self, step_details: Any) -> None:
|
||||||
|
tld = current_app.config["THREAD_LOCAL_DATA"]
|
||||||
|
if hasattr(tld, "locked_by_prefix") and len(step_details) > 0:
|
||||||
|
locked_by_prefix = tld.locked_by_prefix
|
||||||
|
message = (
|
||||||
|
f"ADDING SPIFF BULK STEP DETAILS: {locked_by_prefix}: {step_details}"
|
||||||
|
)
|
||||||
|
current_app.logger.debug(message)
|
||||||
|
|
||||||
def cancel_notify(self) -> None:
|
def cancel_notify(self) -> None:
|
||||||
"""Cancel_notify."""
|
"""Cancel_notify."""
|
||||||
self.__cancel_notify(self.bpmn_process_instance)
|
self.__cancel_notify(self.bpmn_process_instance)
|
||||||
|
|
|
@ -7,6 +7,7 @@ from typing import Optional
|
||||||
import sentry_sdk
|
import sentry_sdk
|
||||||
from flask import current_app
|
from flask import current_app
|
||||||
from SpiffWorkflow.task import Task as SpiffTask # type: ignore
|
from SpiffWorkflow.task import Task as SpiffTask # type: ignore
|
||||||
|
from sqlalchemy import or_
|
||||||
|
|
||||||
from spiffworkflow_backend import db
|
from spiffworkflow_backend import db
|
||||||
from spiffworkflow_backend.exceptions.api_error import ApiError
|
from spiffworkflow_backend.exceptions.api_error import ApiError
|
||||||
|
@ -74,7 +75,13 @@ class ProcessInstanceService:
|
||||||
"""Do_waiting."""
|
"""Do_waiting."""
|
||||||
records = (
|
records = (
|
||||||
db.session.query(ProcessInstanceModel)
|
db.session.query(ProcessInstanceModel)
|
||||||
.filter(ProcessInstanceModel.status == ProcessInstanceStatus.waiting.value)
|
.filter(
|
||||||
|
or_(
|
||||||
|
ProcessInstanceModel.status == ProcessInstanceStatus.waiting.value,
|
||||||
|
ProcessInstanceModel.status
|
||||||
|
== ProcessInstanceStatus.user_input_required.value,
|
||||||
|
)
|
||||||
|
)
|
||||||
.all()
|
.all()
|
||||||
)
|
)
|
||||||
process_instance_lock_prefix = "Background"
|
process_instance_lock_prefix = "Background"
|
||||||
|
|
|
@ -1,12 +1,11 @@
|
||||||
"""Test_get_localtime."""
|
"""Test_get_localtime."""
|
||||||
from spiffworkflow_backend.services.authorization_service import AuthorizationService
|
|
||||||
from tests.spiffworkflow_backend.helpers.test_data import load_test_spec
|
|
||||||
|
|
||||||
from flask.app import Flask
|
from flask.app import Flask
|
||||||
from flask.testing import FlaskClient
|
from flask.testing import FlaskClient
|
||||||
from tests.spiffworkflow_backend.helpers.base_test import BaseTest
|
from tests.spiffworkflow_backend.helpers.base_test import BaseTest
|
||||||
|
from tests.spiffworkflow_backend.helpers.test_data import load_test_spec
|
||||||
|
|
||||||
from spiffworkflow_backend.models.user import UserModel
|
from spiffworkflow_backend.models.user import UserModel
|
||||||
|
from spiffworkflow_backend.services.authorization_service import AuthorizationService
|
||||||
from spiffworkflow_backend.services.process_instance_processor import (
|
from spiffworkflow_backend.services.process_instance_processor import (
|
||||||
ProcessInstanceProcessor,
|
ProcessInstanceProcessor,
|
||||||
)
|
)
|
||||||
|
@ -16,7 +15,6 @@ from spiffworkflow_backend.services.process_instance_service import (
|
||||||
|
|
||||||
|
|
||||||
class TestGetProcessInitiatorUser(BaseTest):
|
class TestGetProcessInitiatorUser(BaseTest):
|
||||||
|
|
||||||
def test_get_process_initiator_user(
|
def test_get_process_initiator_user(
|
||||||
self,
|
self,
|
||||||
app: Flask,
|
app: Flask,
|
||||||
|
|
Loading…
Reference in New Issue