Added Parallel Gateway Example and Reset Process (#1811)
* Added Parallel Gateway Example and Reset Process * Apply suggestions from code review Co-authored-by: coderabbitai[bot] <136622811+coderabbitai[bot]@users.noreply.github.com> --------- Co-authored-by: Kevin Burnett <18027+burnettk@users.noreply.github.com> Co-authored-by: coderabbitai[bot] <136622811+coderabbitai[bot]@users.noreply.github.com>
@ -116,6 +116,12 @@ Since a Parallel Gateway does not dictate the flow based on conditions, it avoid
|
|||||||
**Join:**
|
**Join:**
|
||||||
Note that the behavior for a parallel join, also known as a Parallel Gateway merge, is to synchronize and consolidate multiple parallel paths into a single flow. When the process flow reaches the parallel join, it evaluates the completion of all incoming sequence flows from the corresponding parallel split. It ensures that all parallel paths have completed their execution before the process continues along the single outgoing sequence flow after the join.
|
Note that the behavior for a parallel join, also known as a Parallel Gateway merge, is to synchronize and consolidate multiple parallel paths into a single flow. When the process flow reaches the parallel join, it evaluates the completion of all incoming sequence flows from the corresponding parallel split. It ensures that all parallel paths have completed their execution before the process continues along the single outgoing sequence flow after the join.
|
||||||
|
|
||||||
|
Check out this detailed parallel gateway example:
|
||||||
|
```{toctree}
|
||||||
|
:maxdepth: 1
|
||||||
|
parallelgatewayexample.md
|
||||||
|
```
|
||||||
|
|
||||||
## Event-Based Gateway
|
## Event-Based Gateway
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/fbbee/fbbeeb30a40aa60620bd14cd66903153d5b1c823" alt="event_based_gateway"
|
data:image/s3,"s3://crabby-images/fbbee/fbbeeb30a40aa60620bd14cd66903153d5b1c823" alt="event_based_gateway"
|
||||||
|
BIN
docs/Building_Diagrams/images/parallel_gateway_ex1.png
Normal file
After Width: | Height: | Size: 9.1 KiB |
BIN
docs/Building_Diagrams/images/parallel_gateway_ex2.png
Normal file
After Width: | Height: | Size: 2.2 KiB |
27
docs/Building_Diagrams/parallelgatewayexample.md
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
# Parallel Gateways Example
|
||||||
|
|
||||||
|
## Overview
|
||||||
|
|
||||||
|
This example illustrates the use of parallel gateways in BPMN models to manage and synchronize concurrent tasks effectively.
|
||||||
|
|
||||||
|
Parallel gateways are powerful BPMN elements that split a process flow into multiple independent flows, allowing for simultaneous execution of tasks, and later merging these flows to ensure coordination before moving forward.
|
||||||
|
|
||||||
|
### Process Steps
|
||||||
|
data:image/s3,"s3://crabby-images/860fd/860fd14f38bdc52128b0da38659e0ce7e168aef0" alt="Parallel Gateway Example"
|
||||||
|
1. **Parallel Gateway (Split)**: After the start event, the gateway divides the main flow into two separate paths, enabling tasks to be processed in parallel.
|
||||||
|
|
||||||
|
2. **Sequence Flow 1: Script Task [y = 1]**: Assigns the value `1` to variable y. This script task initializes variable y and demonstrates setting a simple variable in one branch of the parallel flow.
|
||||||
|
|
||||||
|
3. **Sequence Flow 2: Script Task [z = 2]**: Similar to the first script task, this operation assigns the value `2` to variable `z`. Functions concurrently with the first script task, demonstrating the capability of the BPMN model to handle multiple operations at the same time.
|
||||||
|
|
||||||
|
4. **Parallel Gateway (Merge)**: This merging gateway reunites the divergent paths after independent task completion, ensuring all parallel processes are complete before moving forward. It acts as a critical checkpoint in the process to synchronize and consolidate data from multiple sources, ensuring that no task moves forward until all parallel tasks have concluded.
|
||||||
|
|
||||||
|
5. **Script Task [x = y + z]**: Computes the sum of `y` and `z` and assigns it to variable `x`.
|
||||||
|
- **Script**: `x = y + z`
|
||||||
|
- This script task demonstrates the aggregation or combination of results from parallel tasks, highlighting how data from independent branches can be combined.
|
||||||
|
|
||||||
|
After the script task, Signals the successful completion of the process with End Event.
|
||||||
|
|
||||||
|
**Output**:
|
||||||
|
After running the task, it will compute and show the result:
|
||||||
|
data:image/s3,"s3://crabby-images/be4a7/be4a7a6d2c7cbc34e360abb2ec6e582622259a0b" alt="Parallel Gateway Example"
|
BIN
docs/Support/images/reset_process.png
Normal file
After Width: | Height: | Size: 27 KiB |
BIN
docs/Support/images/reset_process1.png
Normal file
After Width: | Height: | Size: 18 KiB |
BIN
docs/Support/images/reset_process2.png
Normal file
After Width: | Height: | Size: 4.3 KiB |
BIN
docs/Support/images/reset_process3.png
Normal file
After Width: | Height: | Size: 182 KiB |
BIN
docs/Support/images/reset_process4.png
Normal file
After Width: | Height: | Size: 234 KiB |
BIN
docs/Support/images/reset_process5.png
Normal file
After Width: | Height: | Size: 148 KiB |
BIN
docs/Support/images/reset_process6.png
Normal file
After Width: | Height: | Size: 5.5 KiB |
@ -92,3 +92,44 @@ There are various reasons for terminating a process instance such as the instanc
|
|||||||
| Confirm that the status has changed from ‘suspended’ to 'terminated'
|
| Confirm that the status has changed from ‘suspended’ to 'terminated'
|
||||||
data:image/s3,"s3://crabby-images/65fdd/65fdd73cba6bf2f2621ed486173a689bb862a120" alt="suspend" |
|
data:image/s3,"s3://crabby-images/65fdd/65fdd73cba6bf2f2621ed486173a689bb862a120" alt="suspend" |
|
||||||
|
|
||||||
|
## Reset a Process
|
||||||
|
> **Step 1: Find the active Process Instance**
|
||||||
|
|
||||||
|
> **Step 2: Navigate to the active User Task**
|
||||||
|
|
||||||
|
👤 Note that you need Admin rights to complete the following steps.
|
||||||
|
|
||||||
|
> **Step 3: Suspend the Process**
|
||||||
|
|
||||||
|
Ensure the status has changed from *user_input_required* to *suspended*
|
||||||
|
data:image/s3,"s3://crabby-images/6c323/6c3235519593d3607fae368d48aa0abfde8dd4d4" alt="Reset"
|
||||||
|
> **Step 4: Go to the relevant past activity**
|
||||||
|
|
||||||
|
Only a previously completed section highlighted in grey can be chosen.
|
||||||
|
|
||||||
|
> **Step 5: Select 'View process instance at the time when this task was active.**
|
||||||
|
|
||||||
|
data:image/s3,"s3://crabby-images/75ea0/75ea0f420ffd3ac7df949f779d1c447537c047e1" alt="Reset"
|
||||||
|
|
||||||
|
> **Step 6: Observe the task once highlighted in grey should now be yellow.**
|
||||||
|
|
||||||
|
A previously completed section is now active and shown in yellow.
|
||||||
|
|
||||||
|
> **Step 7: Select 'Reset Process Here’ icon in the popup window.**
|
||||||
|
|
||||||
|
data:image/s3,"s3://crabby-images/0a997/0a99774c7d42c0f480322853311eaf5dc634c319" alt="Reset"
|
||||||
|
|
||||||
|
> **Step 8: "Resume" process instance.**
|
||||||
|
The process instance should be resumed by selecting the ‘Resume’ icon next to the Process Instance Id
|
||||||
|
|
||||||
|
data:image/s3,"s3://crabby-images/d566a/d566ad609bc36a755f00099088ef24570bb5c09f" alt="Reset"
|
||||||
|
|
||||||
|
|
||||||
|
> **Step 9: Refresh page**
|
||||||
|
|
||||||
|
Wait for Resume action to complete, this may take some time. Refresh the page to ensure it has transitioned to the next activity, replacing the current one.
|
||||||
|
|
||||||
|
<aside>
|
||||||
|
✅ From this point onward, the remaining part of the process can smoothly proceed.
|
||||||
|
|
||||||
|
</aside>
|
||||||
|