mirror of
https://github.com/sartography/spiff-arena.git
synced 2025-01-12 02:24:15 +00:00
Revert "Feature/better subworkflow management (#331)"
This reverts commit 23af5cbbe4015f8bea28fb2b26bbd0c04bfa04e1.
This commit is contained in:
parent
23af5cbbe4
commit
48dcde8faf
@ -1,32 +0,0 @@
|
|||||||
#!/usr/bin/env bash
|
|
||||||
|
|
||||||
function error_handler() {
|
|
||||||
>&2 echo "Exited with BAD EXIT CODE '${2}' in ${0} script at line: ${1}."
|
|
||||||
exit "$2"
|
|
||||||
}
|
|
||||||
trap 'error_handler ${LINENO} $?' ERR
|
|
||||||
set -o errtrace -o errexit -o nounset -o pipefail
|
|
||||||
|
|
||||||
mysql -uroot spiffworkflow_backend_local_development -e '
|
|
||||||
SELECT td.bpmn_identifier FROM process_instance p
|
|
||||||
|
|
||||||
JOIN process_instance_event pie ON pie.process_instance_id = p.id
|
|
||||||
JOIN task t ON t.guid = pie.task_guid
|
|
||||||
JOIN task_definition td ON td.id = t.task_definition_id
|
|
||||||
|
|
||||||
JOIN (
|
|
||||||
SELECT max(pie.id) as max_pie_id
|
|
||||||
FROM process_instance_event pie
|
|
||||||
|
|
||||||
JOIN task t ON t.guid = pie.task_guid
|
|
||||||
JOIN task_definition td ON td.id = t.task_definition_id
|
|
||||||
JOIN bpmn_process bp ON bp.id = t.bpmn_process_id
|
|
||||||
|
|
||||||
WHERE td.typename = "IntermediateThrowEvent" OR (bp.direct_parent_process_id is NULL AND td.typename IN ("SimpleBpmnTask", "BpmnStartTask"))
|
|
||||||
|
|
||||||
GROUP BY pie.process_instance_id
|
|
||||||
) AS max_pie ON max_pie.max_pie_id = pie.id
|
|
||||||
|
|
||||||
WHERE pie.process_instance_id = 27
|
|
||||||
;
|
|
||||||
'
|
|
2
spiffworkflow-backend/poetry.lock
generated
2
spiffworkflow-backend/poetry.lock
generated
@ -2385,7 +2385,7 @@ lxml = "*"
|
|||||||
type = "git"
|
type = "git"
|
||||||
url = "https://github.com/sartography/SpiffWorkflow"
|
url = "https://github.com/sartography/SpiffWorkflow"
|
||||||
reference = "main"
|
reference = "main"
|
||||||
resolved_reference = "dbe41c8e3e082b7a4e6e207a2c82bd55685a92fc"
|
resolved_reference = "efcdcf545c861d58cfae92ad070b3208ef6028db"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "sqlalchemy"
|
name = "sqlalchemy"
|
||||||
|
@ -30,6 +30,7 @@ flask-restful = "*"
|
|||||||
flask-simple-crypt = "^0.3.3"
|
flask-simple-crypt = "^0.3.3"
|
||||||
werkzeug = "*"
|
werkzeug = "*"
|
||||||
SpiffWorkflow = {git = "https://github.com/sartography/SpiffWorkflow", rev = "main"}
|
SpiffWorkflow = {git = "https://github.com/sartography/SpiffWorkflow", rev = "main"}
|
||||||
|
# SpiffWorkflow = {git = "https://github.com/sartography/SpiffWorkflow", rev = "6cad2981712bb61eca23af1adfafce02d3277cb9"}
|
||||||
# SpiffWorkflow = {develop = true, path = "../../spiffworkflow/" }
|
# SpiffWorkflow = {develop = true, path = "../../spiffworkflow/" }
|
||||||
sentry-sdk = "^1.10"
|
sentry-sdk = "^1.10"
|
||||||
# sphinx-autoapi = "^2.0"
|
# sphinx-autoapi = "^2.0"
|
||||||
|
@ -1,4 +1,3 @@
|
|||||||
from SpiffWorkflow.bpmn.workflow import BpmnMessage # type: ignore
|
|
||||||
from spiffworkflow_backend.models.db import db
|
from spiffworkflow_backend.models.db import db
|
||||||
from spiffworkflow_backend.models.message_instance import MessageInstanceModel
|
from spiffworkflow_backend.models.message_instance import MessageInstanceModel
|
||||||
from spiffworkflow_backend.models.message_instance import MessageStatuses
|
from spiffworkflow_backend.models.message_instance import MessageStatuses
|
||||||
@ -144,13 +143,8 @@ class MessageService:
|
|||||||
message_model_name: str,
|
message_model_name: str,
|
||||||
message_payload: dict,
|
message_payload: dict,
|
||||||
) -> None:
|
) -> None:
|
||||||
bpmn_message = BpmnMessage(
|
|
||||||
None,
|
|
||||||
message_model_name,
|
|
||||||
message_payload,
|
|
||||||
)
|
|
||||||
processor_receive = ProcessInstanceProcessor(process_instance_receive)
|
processor_receive = ProcessInstanceProcessor(process_instance_receive)
|
||||||
processor_receive.bpmn_process_instance.catch_bpmn_message(bpmn_message)
|
processor_receive.bpmn_process_instance.catch_bpmn_message(message_model_name, message_payload)
|
||||||
processor_receive.do_engine_steps(save=True)
|
processor_receive.do_engine_steps(save=True)
|
||||||
message_instance_receive.status = MessageStatuses.completed.value
|
message_instance_receive.status = MessageStatuses.completed.value
|
||||||
db.session.add(message_instance_receive)
|
db.session.add(message_instance_receive)
|
||||||
|
@ -1018,7 +1018,7 @@ class ProcessInstanceProcessor:
|
|||||||
|
|
||||||
# in the xml, it's the id attribute. this identifies the process where the activity lives.
|
# in the xml, it's the id attribute. this identifies the process where the activity lives.
|
||||||
# if it's in a subprocess, it's the inner process.
|
# if it's in a subprocess, it's the inner process.
|
||||||
bpmn_process_identifier = ready_or_waiting_task.workflow.spec.name
|
bpmn_process_identifier = ready_or_waiting_task.workflow.name
|
||||||
|
|
||||||
form_file_name = None
|
form_file_name = None
|
||||||
ui_form_file_name = None
|
ui_form_file_name = None
|
||||||
@ -1081,6 +1081,9 @@ class ProcessInstanceProcessor:
|
|||||||
event_definition = self._event_serializer.registry.restore(event_data)
|
event_definition = self._event_serializer.registry.restore(event_data)
|
||||||
if payload is not None:
|
if payload is not None:
|
||||||
event_definition.payload = payload
|
event_definition.payload = payload
|
||||||
|
current_app.logger.info(
|
||||||
|
f"Event of type {event_definition.event_type} sent to process instance {self.process_instance_model.id}"
|
||||||
|
)
|
||||||
try:
|
try:
|
||||||
self.bpmn_process_instance.catch(event_definition)
|
self.bpmn_process_instance.catch(event_definition)
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
|
@ -157,7 +157,7 @@ class TaskService:
|
|||||||
"""
|
"""
|
||||||
(parent_subprocess_guid, _parent_subprocess) = self.__class__._task_subprocess(spiff_task)
|
(parent_subprocess_guid, _parent_subprocess) = self.__class__._task_subprocess(spiff_task)
|
||||||
if parent_subprocess_guid is not None:
|
if parent_subprocess_guid is not None:
|
||||||
spiff_task_of_parent_subprocess = spiff_task.workflow.top_workflow.get_task_from_id(
|
spiff_task_of_parent_subprocess = spiff_task.workflow._get_outermost_workflow().get_task_from_id(
|
||||||
UUID(parent_subprocess_guid)
|
UUID(parent_subprocess_guid)
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -242,11 +242,11 @@ class TaskService:
|
|||||||
|
|
||||||
self.bpmn_processes[bpmn_process.guid or "top_level"] = bpmn_process
|
self.bpmn_processes[bpmn_process.guid or "top_level"] = bpmn_process
|
||||||
|
|
||||||
if spiff_workflow.parent_task_id:
|
if spiff_workflow.outer_workflow != spiff_workflow:
|
||||||
direct_parent_bpmn_process = BpmnProcessModel.query.filter_by(
|
direct_parent_bpmn_process = BpmnProcessModel.query.filter_by(
|
||||||
id=bpmn_process.direct_parent_process_id
|
id=bpmn_process.direct_parent_process_id
|
||||||
).first()
|
).first()
|
||||||
self.update_bpmn_process(spiff_workflow.parent_workflow, direct_parent_bpmn_process)
|
self.update_bpmn_process(spiff_workflow.outer_workflow, direct_parent_bpmn_process)
|
||||||
|
|
||||||
def update_task_model(
|
def update_task_model(
|
||||||
self,
|
self,
|
||||||
@ -311,7 +311,7 @@ class TaskService:
|
|||||||
# This is the top level workflow, which has no guid
|
# This is the top level workflow, which has no guid
|
||||||
# check for bpmn_process_id because mypy doesn't realize bpmn_process can be None
|
# check for bpmn_process_id because mypy doesn't realize bpmn_process can be None
|
||||||
if self.process_instance.bpmn_process_id is None:
|
if self.process_instance.bpmn_process_id is None:
|
||||||
spiff_workflow = spiff_task.workflow.top_workflow
|
spiff_workflow = spiff_task.workflow._get_outermost_workflow()
|
||||||
bpmn_process = self.add_bpmn_process(
|
bpmn_process = self.add_bpmn_process(
|
||||||
bpmn_process_dict=self.serializer.workflow_to_dict(spiff_workflow),
|
bpmn_process_dict=self.serializer.workflow_to_dict(spiff_workflow),
|
||||||
spiff_workflow=spiff_workflow,
|
spiff_workflow=spiff_workflow,
|
||||||
@ -321,7 +321,7 @@ class TaskService:
|
|||||||
if bpmn_process is None:
|
if bpmn_process is None:
|
||||||
spiff_workflow = spiff_task.workflow
|
spiff_workflow = spiff_task.workflow
|
||||||
bpmn_process = self.add_bpmn_process(
|
bpmn_process = self.add_bpmn_process(
|
||||||
bpmn_process_dict=self.serializer.subworkflow_to_dict(subprocess),
|
bpmn_process_dict=self.serializer.workflow_to_dict(subprocess),
|
||||||
top_level_process=self.process_instance.bpmn_process,
|
top_level_process=self.process_instance.bpmn_process,
|
||||||
bpmn_process_guid=subprocess_guid,
|
bpmn_process_guid=subprocess_guid,
|
||||||
spiff_workflow=spiff_workflow,
|
spiff_workflow=spiff_workflow,
|
||||||
@ -369,10 +369,10 @@ class TaskService:
|
|||||||
bpmn_process.bpmn_process_definition = bpmn_process_definition
|
bpmn_process.bpmn_process_definition = bpmn_process_definition
|
||||||
|
|
||||||
if top_level_process is not None:
|
if top_level_process is not None:
|
||||||
subprocesses = spiff_workflow.top_workflow.subprocesses
|
subprocesses = spiff_workflow._get_outermost_workflow().subprocesses
|
||||||
direct_bpmn_process_parent = top_level_process
|
direct_bpmn_process_parent = top_level_process
|
||||||
for subprocess_guid, subprocess in subprocesses.items():
|
for subprocess_guid, subprocess in subprocesses.items():
|
||||||
if subprocess == spiff_workflow.parent_workflow:
|
if subprocess == spiff_workflow.outer_workflow:
|
||||||
direct_bpmn_process_parent = BpmnProcessModel.query.filter_by(
|
direct_bpmn_process_parent = BpmnProcessModel.query.filter_by(
|
||||||
guid=str(subprocess_guid)
|
guid=str(subprocess_guid)
|
||||||
).first()
|
).first()
|
||||||
@ -674,7 +674,7 @@ class TaskService:
|
|||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def _task_subprocess(cls, spiff_task: SpiffTask) -> tuple[str | None, BpmnWorkflow | None]:
|
def _task_subprocess(cls, spiff_task: SpiffTask) -> tuple[str | None, BpmnWorkflow | None]:
|
||||||
top_level_workflow = spiff_task.workflow.top_workflow
|
top_level_workflow = spiff_task.workflow._get_outermost_workflow()
|
||||||
my_wf = spiff_task.workflow # This is the workflow the spiff_task is part of
|
my_wf = spiff_task.workflow # This is the workflow the spiff_task is part of
|
||||||
my_sp = None
|
my_sp = None
|
||||||
my_sp_id = None
|
my_sp_id = None
|
||||||
|
@ -451,6 +451,7 @@ class WorkflowExecutionService:
|
|||||||
def queue_waiting_receive_messages(self) -> None:
|
def queue_waiting_receive_messages(self) -> None:
|
||||||
waiting_events = self.bpmn_process_instance.waiting_events()
|
waiting_events = self.bpmn_process_instance.waiting_events()
|
||||||
waiting_message_events = filter(lambda e: e["event_type"] == "MessageEventDefinition", waiting_events)
|
waiting_message_events = filter(lambda e: e["event_type"] == "MessageEventDefinition", waiting_events)
|
||||||
|
|
||||||
for event in waiting_message_events:
|
for event in waiting_message_events:
|
||||||
# Ensure we are only creating one message instance for each waiting message
|
# Ensure we are only creating one message instance for each waiting message
|
||||||
if (
|
if (
|
||||||
|
@ -12,18 +12,18 @@
|
|||||||
</bpmn:collaboration>
|
</bpmn:collaboration>
|
||||||
<bpmn:correlationProperty id="customer_id" name="Customer Id">
|
<bpmn:correlationProperty id="customer_id" name="Customer Id">
|
||||||
<bpmn:correlationPropertyRetrievalExpression messageRef="request_approval">
|
<bpmn:correlationPropertyRetrievalExpression messageRef="request_approval">
|
||||||
<bpmn:messagePath>customer_id</bpmn:messagePath>
|
<bpmn:formalExpression>customer_id</bpmn:formalExpression>
|
||||||
</bpmn:correlationPropertyRetrievalExpression>
|
</bpmn:correlationPropertyRetrievalExpression>
|
||||||
<bpmn:correlationPropertyRetrievalExpression messageRef="approval_result">
|
<bpmn:correlationPropertyRetrievalExpression messageRef="approval_result">
|
||||||
<bpmn:messagePath>customer_id</bpmn:messagePath>
|
<bpmn:formalExpression>customer_id</bpmn:formalExpression>
|
||||||
</bpmn:correlationPropertyRetrievalExpression>
|
</bpmn:correlationPropertyRetrievalExpression>
|
||||||
</bpmn:correlationProperty>
|
</bpmn:correlationProperty>
|
||||||
<bpmn:correlationProperty id="po_number" name="Purchase Order Number">
|
<bpmn:correlationProperty id="po_number" name="Purchase Order Number">
|
||||||
<bpmn:correlationPropertyRetrievalExpression messageRef="request_approval">
|
<bpmn:correlationPropertyRetrievalExpression messageRef="request_approval">
|
||||||
<bpmn:messagePath>po_number</bpmn:messagePath>
|
<bpmn:formalExpression>po_number</bpmn:formalExpression>
|
||||||
</bpmn:correlationPropertyRetrievalExpression>
|
</bpmn:correlationPropertyRetrievalExpression>
|
||||||
<bpmn:correlationPropertyRetrievalExpression messageRef="approval_result">
|
<bpmn:correlationPropertyRetrievalExpression messageRef="approval_result">
|
||||||
<bpmn:messagePath>po_number</bpmn:messagePath>
|
<bpmn:formalExpression>po_number</bpmn:formalExpression>
|
||||||
</bpmn:correlationPropertyRetrievalExpression>
|
</bpmn:correlationPropertyRetrievalExpression>
|
||||||
</bpmn:correlationProperty>
|
</bpmn:correlationProperty>
|
||||||
<bpmn:message id="request_approval" name="Request Approval">
|
<bpmn:message id="request_approval" name="Request Approval">
|
||||||
|
@ -18,18 +18,18 @@ It will fire a message connected to the invoice keys above, starting another pro
|
|||||||
</bpmn:collaboration>
|
</bpmn:collaboration>
|
||||||
<bpmn:correlationProperty id="po_number" name="Purchase Order Number">
|
<bpmn:correlationProperty id="po_number" name="Purchase Order Number">
|
||||||
<bpmn:correlationPropertyRetrievalExpression messageRef="request_approval">
|
<bpmn:correlationPropertyRetrievalExpression messageRef="request_approval">
|
||||||
<bpmn:messagePath>po_number</bpmn:messagePath>
|
<bpmn:formalExpression>po_number</bpmn:formalExpression>
|
||||||
</bpmn:correlationPropertyRetrievalExpression>
|
</bpmn:correlationPropertyRetrievalExpression>
|
||||||
<bpmn:correlationPropertyRetrievalExpression messageRef="approval_result">
|
<bpmn:correlationPropertyRetrievalExpression messageRef="approval_result">
|
||||||
<bpmn:messagePath>po_number</bpmn:messagePath>
|
<bpmn:formalExpression>po_number</bpmn:formalExpression>
|
||||||
</bpmn:correlationPropertyRetrievalExpression>
|
</bpmn:correlationPropertyRetrievalExpression>
|
||||||
</bpmn:correlationProperty>
|
</bpmn:correlationProperty>
|
||||||
<bpmn:correlationProperty id="customer_id" name="Customer ID">
|
<bpmn:correlationProperty id="customer_id" name="Customer ID">
|
||||||
<bpmn:correlationPropertyRetrievalExpression messageRef="request_approval">
|
<bpmn:correlationPropertyRetrievalExpression messageRef="request_approval">
|
||||||
<bpmn:messagePath>customer_id</bpmn:messagePath>
|
<bpmn:formalExpression>customer_id</bpmn:formalExpression>
|
||||||
</bpmn:correlationPropertyRetrievalExpression>
|
</bpmn:correlationPropertyRetrievalExpression>
|
||||||
<bpmn:correlationPropertyRetrievalExpression messageRef="approval_result">
|
<bpmn:correlationPropertyRetrievalExpression messageRef="approval_result">
|
||||||
<bpmn:messagePath>customer_id</bpmn:messagePath>
|
<bpmn:formalExpression>customer_id</bpmn:formalExpression>
|
||||||
</bpmn:correlationPropertyRetrievalExpression>
|
</bpmn:correlationPropertyRetrievalExpression>
|
||||||
</bpmn:correlationProperty>
|
</bpmn:correlationProperty>
|
||||||
<bpmn:process id="message_send_process" name="Message Send Process" isExecutable="true">
|
<bpmn:process id="message_send_process" name="Message Send Process" isExecutable="true">
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
import pytest
|
import pytest
|
||||||
from flask import Flask
|
from flask import Flask
|
||||||
from flask.testing import FlaskClient
|
from flask.testing import FlaskClient
|
||||||
from spiffworkflow_backend.models.db import db
|
from spiffworkflow_backend import db
|
||||||
from spiffworkflow_backend.models.message_instance import MessageInstanceModel
|
from spiffworkflow_backend.models.message_instance import MessageInstanceModel
|
||||||
from spiffworkflow_backend.models.process_instance import ProcessInstanceModel
|
from spiffworkflow_backend.models.process_instance import ProcessInstanceModel
|
||||||
from spiffworkflow_backend.models.process_instance import ProcessInstanceStatus
|
from spiffworkflow_backend.models.process_instance import ProcessInstanceStatus
|
||||||
|
@ -74,7 +74,6 @@ describe('process-models', () => {
|
|||||||
cy.contains(`${jsonFileName}.json`).should('not.exist');
|
cy.contains(`${jsonFileName}.json`).should('not.exist');
|
||||||
|
|
||||||
// add new bpmn file
|
// add new bpmn file
|
||||||
cy.getBySel('process-model-add-file').click();
|
|
||||||
cy.contains('New BPMN File').click();
|
cy.contains('New BPMN File').click();
|
||||||
cy.contains(/^Process Model File$/);
|
cy.contains(/^Process Model File$/);
|
||||||
cy.get('g[data-element-id=StartEvent_1]').click();
|
cy.get('g[data-element-id=StartEvent_1]').click();
|
||||||
@ -93,7 +92,6 @@ describe('process-models', () => {
|
|||||||
cy.contains(`${bpmnFileName}.bpmn`).should('exist');
|
cy.contains(`${bpmnFileName}.bpmn`).should('exist');
|
||||||
|
|
||||||
// add new dmn file
|
// add new dmn file
|
||||||
cy.getBySel('process-model-add-file').click();
|
|
||||||
cy.contains('New DMN File').click();
|
cy.contains('New DMN File').click();
|
||||||
cy.contains(/^Process Model File$/);
|
cy.contains(/^Process Model File$/);
|
||||||
cy.get('g[data-element-id=decision_1]').click();
|
cy.get('g[data-element-id=decision_1]').click();
|
||||||
@ -111,7 +109,6 @@ describe('process-models', () => {
|
|||||||
cy.contains(`${dmnFileName}.dmn`).should('exist');
|
cy.contains(`${dmnFileName}.dmn`).should('exist');
|
||||||
|
|
||||||
// add new json file
|
// add new json file
|
||||||
cy.getBySel('process-model-add-file').click();
|
|
||||||
cy.contains('New JSON File').click();
|
cy.contains('New JSON File').click();
|
||||||
cy.contains(/^Process Model File$/);
|
cy.contains(/^Process Model File$/);
|
||||||
// Some reason, cypress evals json strings so we have to escape it it with '{{}'
|
// Some reason, cypress evals json strings so we have to escape it it with '{{}'
|
||||||
|
@ -526,7 +526,6 @@ export default function ProcessModelShow() {
|
|||||||
size="lg"
|
size="lg"
|
||||||
label="Add File"
|
label="Add File"
|
||||||
type="inline"
|
type="inline"
|
||||||
data-qa="process-model-add-file"
|
|
||||||
onChange={(a: any) => {
|
onChange={(a: any) => {
|
||||||
if (a.selectedItem.text === 'New BPMN File') {
|
if (a.selectedItem.text === 'New BPMN File') {
|
||||||
navigate(
|
navigate(
|
||||||
|
Loading…
x
Reference in New Issue
Block a user