Boundary Events
Non-interrupting timer boundary events were introduced in beta in Studio Pro 10.15 and released in GA in Studio Pro 10.16.
Interrupting timer boundary events were introduced in Studio Pro 10.20 and are currently in beta. Certain features or attributes are subject to change and may contain bugs. For more information, see Beta and Experimental Releases.
Introduction
Based on Business Process Model and Notation (BPMN) 2.0, boundary events are a type of event that is attached to the boundary of an activity (such as a task or a sub-process) to handle exceptional situations or are triggered by certain behaviors.
There are two main types of boundary events:
-
Non-interrupting boundary events: These events do not interrupt the ongoing activity. When triggered, they allow the activity to continue while simultaneously starting a new path from the boundary event. Use non-interrupting boundary events when the parent activity should remain active, but you would like to do something in parallel. For example, after 2 days, a reminder should be sent to the assigned user. As per BPMN 2.0 specification, non-interrupting boundary events are visualized as two dashed circles with an icon in the center.
-
Interrupting boundary events (currently in beta): When these events are triggered, they interrupt the activity they are attached to, meaning that this activity will be aborted. The process flow is redirected to the boundary event’s outgoing sequence path. Use interrupting boundary event in situations where further execution of the activity (and other following activities) is not required and an alternative path should be taken. For example, use an interrupting boundary event to start an escalation or a fast-track path when an activity is not completed 2 days after the due date. Or when the assigned user does not make a decision within 5 days, you want to abort the user task and continue the process with a pre-set decision. As per BPMN 2.0 specification, interrupting boundary events are visualized as two solid circles.
Boundary Events are always displayed by 2 circles (either solid or dashed) and are linked by a dotted line to the parent activity. The icon inside the event indicates the type of event. For example, a clock indicates that it is a timer boundary event.
Below is an example of what a non-interrupting timer boundary event looks like:

Studio Pro now supports the following boundary event:
Getting started
You can add boundary events to the following activities:
Adding Boundary Events
To add a boundary event to the above-listed activities, choose one of the following ways:
-
Select an event from the Events section in the workflow Toolbox and drag it onto one of the activities listed above:
-
Right-click one of the above-listed activities to open its context menu, and click Add boundary event:
-
Double-click one of the above-listed activities to open its properties dialog box, go to the Events tab, and in the > Boundary events section, click Add timer event to add a timer boundary event:
To configure the properties of a boundary event, double-click the event to open its properties dialog box. For more information on how to configure the properties of a timer boundary event, see the Properties section in Timer.
Enabling and Adding Interrupting Boundary Events (Beta)
Interrupting boundary events are currently in beta. To enable this feature, go to Studio Pro Preferences -> New features -> Workflow editor > Enable interrupting timer boundary events (beta):

After interrupting boundary events are enabled, the Boundary properties section is displayed in the properties dialog box of a boundary event.
By default, the Interrupting property is set to No, which means that the initially added event is a non-interrupting boundary event. To add an interrupting boundary event, set the Interrupting property to Yes. Click OK to save your configuration:

Implications of Changing the Boundary Event Type
For an existing boundary event, when you change its type from non-interrupting to interrupting or vice versa, you will be presented with a warning dialog. For example, when you change a boundary event from non-interrupting to interrupting, you will see the following warning dialog:

After you confirm the change:
- The boundary event is re-created as the specified type. As a result, new IDs are created. These IDs are used by the Mendix Runtime for conflict detection analysis.
- The current activities on the boundary event path including the boundary event itself become incompatible and need to be restarted.
Rearranging Boundary Events
You can rearrange boundary events in the following ways:
-
Right-click a boundary event to open its context menu and click Move boundary event left or Move boundary event right, or use the Ctrl/Command + Left arrow or Ctrl/Command + Right arrow shortcut keys.
-
Double-click the parent activity to open its properties dialog box and click Move up or Move down to change the order of the boundary events’ paths.
This does not change the order execution of the paths, as this is dependent on the expiration of the timer.
Execution
Boundary events are initiated when their parent activity is initiated. For example, for a timer with a fixed duration, it will start its countdown when the parent activity is initiated. When the parent activity is completed before any of the boundary events are triggered, none of the activities in the boundary event path will be executed and all timers will be cancelled.
Non-Interrupting Boundary Events
With non-interrupting boundary events, the parent activity remains active/in progress when an event is triggered (i.e., the parent activity is not interrupted). For example, when a non-interrupting timer boundary event is set on a user task and is triggered after 2 days, this user task will remain in progress and the path following the timer boundary event is executed. When the boundary event path reaches the End of Boundary Path activity, the workflow will await the completion of the parent activity.
Interrupting Boundary Events
However, with interrupting boundary events, the parent activity is aborted. For example, when an interrupting timer boundary event is set on a user task and is triggered after 2 days, this user task will be aborted, and the path following the timer boundary event will become the active path.
Boundary Event Variables
Boundary events have dedicated variables that can be used to get direct access to the values of the parent activity if it is either a user task or Call workflow activity. You can get information such as the parent activity’s DueDate
, which can be used in the boundary event flow and its expressions. For instance, you can use the expression addDays($ParentTask/DueDate, -2)
to configure a timer boundary event so that it is triggered two days before the due date of its parent user task.
The list of variables is described below:
$ParentTask
– the parent user task of the attached boundary event$CalledWorkflowInstance
– the parent Call workflow activity of the attached boundary event
Current Limitations
The current release of boundary events is still under development and has the following limitations:
- Interrupting boundary events are not allowed to be nested in other boundary event paths, meaning that if an activity has a boundary event path (interrupting or non-interrupting), this activity cannot be placed in a boundary event path.
- Interrupting boundary events are not allowed to have a jump at the end of their flow, nor do they allow jumping inside or outside of their flow.
- Non-interrupting timer boundary events currently have no recurrence (they are only executed once and will not repeat).
Read more
- Workflows
- Add Date Function Calls
- Parse and Format Date Function Calls
- Workflow Versioning and Conflict Mitigation