This chapter describes how to handle errors that occur when running a business process. Oracle BPM provides you with an exception component that enables you to model errors and multiple BPMN structures that you can use to handle those errors while running the process.
This chapter includes the following sections:
Section 18.6, "Throwing Exceptions in Subprocesses or Reusable Processes"
Section 18.8, "Handling Errors in a Peer Process Using Message Events"
There might be situations when an unexpected problem occurs causing your process to fail. There are two types of errors: system errors and process errors.
System errors are the consequence of a failure in the software or hardware infrastructure where the BPMN Service Engine is running. A system error can have many causes. The following are examples of problems that can cause a system error:
Failure in the database connection
Connectivity loss
Problem with the hard disk
To recover from system errors within the process flow you can use system exceptions.
If you do not handle a system exception in your process, you can recover from them using the fault recovery system provided by Oracle Enterprise Manager. See Oracle Fusion Middleware Administrator's Guide for Oracle SOA Suite and Oracle Business Process Management Suite for more information about the Oracle Enterprise Manager fault recovery system.
Process errors are problems that interfere with the regular development of your process. For example, in a purchase order process, if there is no stock for the requested item then you cannot continue with the regular process flow. You can handle these unexpected situations within the process flow. One way to handle the situation in this example by letting the customer cancel the order or save it for later.
The following are typical examples of unexpected situations within a process:
Lack of stock
Workload limit exceeded
Expense limit exceeded
Feedback past due
Credit card authentication problems
When an exception occurs in a process, it affects the state of the SOA composite that contains that BPMN process. For more information on how exceptions affect the state of the SOA composite, see Section 15.1.4, "How Do BPMN Errors Affect the SOA Composite Status".
Oracle BPM uses business exceptions to represent unexpected situations that can occur while running a business process.
You can design how to handle an exception as part of the business process, but it is something that occurs outside of the usual flow of a process. The use of business exceptions enables you to create less complicated processes where the main flow follows the typical use cases, and there is a separate flow to handle the process exception.
Business exceptions are considered a normal part of the process design, rather than an error.
When you add a component to the business catalog, if the services in the component specify that they can produce errors, then these errors appear as business exceptions in the business catalog in the Errors predefined module.
An exception can arise when you invoke a service. You can handle these exceptions using a boundary error catch event or an event subprocess.
You can also define business exceptions in the business catalog. Then, you can use those business exceptions in an error end event that is triggered under a certain condition. The error end event generates the exception, and the parent process can handle the exception.
System exceptions represent low level errors that may occur while running a process. In some cases you may require to handle this low level errors within your process.
To handle a system exception within the process flow you must catch the exception and configure the error catch event to use system exceptions.
System exceptions may occur while running a service or another BPMN process. You also design your process to throw certain system exceptions. The only exception that you can use in a throw or end event is Rollback. All the other supported system exceptions are only available for start of catch error events.
System exceptions contain an errorInfo attribute of type Any. You can assign any value to this attribute. Because its type is Any this value can belong to any type. Generally you use this attribute to store the cause of the exception or important information for troubleshooting the application.
You can only view the list of available system exceptions from the Implementation Properties of an error event.
Table 18-1 describes the supported system exceptions. It also specifies the module where the system exception resides and the error events that can use the specified system exception.
| System Exception | Module | Description | Error Event | 
|---|---|---|---|
| AssertFailure | Bpel | Indicates that the specified assertion failed. | Catch, Start | 
| BindingFault | Bpel | Indicates that the preparation of the operation invoked in a flow object failed. For example, the WSD loading failed. You cannot retry the invocation after a BindingFault, recovering from this error generally requires human intervention. | Catch, Start | 
| InvalidVariables | Bpel | Indicated that the variables used are not valid. | Catch, Start | 
| RemoteFault | Bpel | Indicates that there was a problem invoking a service in a flow object. For example, the remote service returned a SOAP fault. | Catch, Start | 
| Timeout | Soap | Indicates that the service exceeded the response time out period. | Catch, Start | 
| ConflictingReceive | Soap | Indicates that there are multiple receive activities to respond to the invoked operation. | Catch, Start | 
| ConflictingRequest | Soap | Indicates that there are multiple requests on the same partner link for the invoked operation. | Catch, Start | 
| CorrelationViolation | Soap | Indicates that the message does not provide the required correlation information. | Catch, Start | 
| ForcedTermination | Soap | Indicates the service terminated because a SOAP fault occurred. | Catch, End | 
| InvalidReply | Soap | Indicates that the reply does not contain the correlation information required by the corresponding receive. | Catch, Start | 
| MismatchedAssignmentFailure | Soap | Indicates the assigned types are incompatible. | Catch, Start | 
| RepeatedCompensation | Soap | Specifies that a compensation handler is invoked multiple times. | Catch, Start | 
| SelectionFailure | Soap | Indicates there was an error running a selection operation. | Catch, Start | 
| UninitializedVariable | Soap | Indicates that the variable you are accessing is not initialized. | Catch, Start | 
| Rollback | Soap | Enables the receiver of the exception to rollback the current JTA transaction from within the process flow. | Throw, End | 
The flow of a system or a business exception depends on where the exception occurred.
Exceptions can occur while running the following:
a task
a subprocess
a reusable process
The following describes what happens when the BPMN Service Engine runs a task that causes an exception.
The BPMN Service Engine runs a task that starts a service that can throw an exception.
The task fails with a SOAP error that the BPMN Service Engine converts into an exception.
If the task has a boundary catch error event attached, then the instance follows the flow defined by the boundary catch error event to handle the exception. The exception handling flow may resume the main process flow. If it does not resume the main process flow, then the process ends in the boundary catch error event.
If the task does not have a boundary catch error event associated with it, then the exception propagates to the process level.
At the process level, the following options are possible:
If the process does not contain an event subprocess that can catch the exception and you did not define a fault policy, then the BPM Service Engine logs this error to the Oracle Enterprise Manager fault recovery system. See Oracle Fusion Middleware Administrator's Guide for Oracle SOA Suite and Oracle Business Process Management Suite for more information about the Oracle Enterprise Manager fault recovery system.
If the process contains an event subprocess with a start event of type error configured to catch that exception, then the instance continues through the exception handling flow. When the instance completes the exception handling flow, the process ends.
The following sequence describes what happens when the BPMN Service Engine runs a subprocess that causes an exception.
The BPM Service Engine runs a subprocess that contains a task that invokes a service that can throw an exception, or an end error event.
One of these events happens:
The task throws an exception.
The subprocess ends with an error event.
If the exception occurs in a task and the task has a boundary catch error event or the subprocess contains an event subprocess that can handle the exception, then the exception is not propagated to the parent process.
If the subprocess ends with an error event, or the exception occurs in a task and is not handled, then the exception propagates to the parent process.
The parent process can handle the exception if:
the subprocess has a boundary catch event attached.
it contains an event subprocess configured to catch the exception.
If the parent process cannot handle the exception, then it propagates it to its parent process. If there is no parent process, then the exception is logged to the Enterprise Manager fault recovery system. See Oracle Fusion Middleware Administrator's Guide for Oracle SOA Suite and Oracle Business Process Management Suite, for more information about the Enterprise Manager fault recovery system.
The following sequence describes what happens when the BPMN Service Engine runs a call activity that invokes a reusable subprocess that causes an exception.
The BPM Service Engine runs a reusable process that contains a task that invokes a service that can throw an exception, or an end error event.
One of these events happens:
The task throws an exception.
The reusable process ends with an error event.
If the exception occurs in a task and the task has a boundary catch error event or the reusable process contains an event subprocess that can handle the exception, then the exception is not propagated to the parent process.
If the subprocess ends with an error event, or the exception occurs in a task and is not handled, then the exception propagates to the parent process.
The parent process can handle the exception if:
the call activity has a boundary catch event attached.
it contains an event subprocess configured to catch the exception.
If the parent process cannot handle the exception, then it propagates it to its parent process. If there is no parent process, then the exception is logged to the Enterprise Manager fault recovery system. See Oracle Fusion Middleware Administrator's Guide for Oracle SOA Suite and Oracle Business Process Management Suite, for more information about the Enterprise Manager fault recovery system.
You can handle the exceptions that occur in an activity using the following:
A boundary error catch event
An event subprocess
Boundary error catch events enable you to resume the main process flow after handling the exception.
If you want to reuse the exception handling flow for multiple tasks in your process, then event subprocesses are more efficient than boundary catch events. Event subprocesses enable you to define a cleaner process with less effort because the catch error event is located within the event subprocess. To reuse an exception handling flow using boundary catch events, you must define a boundary catch event for each of the tasks, and then connect those boundary events to the exception handling flow.
Figure 18-1 shows a process that handles an error using a boundary error catch event.
Event subprocesses also enable you to define data objects that you can access only from within the event subprocess, in the same way that subprocesses enable you to define their own data objects.
Figure 18-2 shows a process that handles an error using a an event subprocess.
Figure 18-2 Event Subprocess with a Start Error Event

If you know that running a flow object can cause an exception, then you can design your process to handle the exception using a boundary error catch event.
To handle an exception using a boundary error catch event:
Create an exception handling flow.
After handling the exception, this flow can resume the main process or end the process.
From the Component Palette, from the Catch Events section select Error Event.
Drop the error event over the task that throws the exception.
You can place the event in any part of the border of the task.
When you drop the error event, a sequence flow appears that you can connect to the exception handling flow.
Connect the sequence flow to the exception handling flow.
Right-click the boundary catch error event.
Select Properties.
Click the Implementation tab.
Configure the implementation properties to catch a business or system exception.
For information on how to configure the implementation properties to catch business exceptions, see Section 18.5.5, "How to Configure an Error Event to Catch Business Exceptions".
For information on how to configure the implementation properties to catch system exceptions, see Section 18.5.6, "How to Configure a Catch Event to Catch System Exceptions".
If the BPMN Service Engine encounters an error while running a task that has a boundary error catch event attached, then it follows the flow defined by the boundary error catch event. The exception handling flow defined by the boundary error catch event can re-join the main process flow or end the process.
You can use an event subprocess to handle an exception that can occur while running any of the flow objects in your BPMN process.
To handle an exception using an event subprocess:
From the Component Palette, from the Activities section, select Event Subprocess.
Drop the event subprocess in the process.
Right-click the start event of the event subprocess.
Select Properties.
Click the Implementation tab.
From the Implementation Type list, select Error.
Configure the implementation properties to catch a business or system exception.
For information on how to configure the implementation properties to catch business exceptions, see Section 18.5.5, "How to Configure an Error Event to Catch Business Exceptions".
For information on how to configure the implementation properties to catch system exceptions, see Section 18.5.6, "How to Configure a Catch Event to Catch System Exceptions".
If the exception handled in the event subprocess occurs while running any of the tasks in the process, then the BPMN Service Engine continues running the exception handling flow defined in the event subprocess.
You can configure an error event to catch business exceptions. To configure an error event to catch business exceptions you must edit the error event implementation properties.
To configure the implementation properties of an error event to catch business exceptions:
If you want to handle all the business exceptions that can occur while running this process, then select Catch All Business Exceptions.
If you want to catch a specific business exception:
Click the Browse button next to the Exception field.
The Type dialog box appears.
Enter the name of the exception or select it from the tree.
Click OK.
The Type dialog box closes and the selected exception appears in the Exception field.
You can configure an error event to catch system exceptions. To configure an error event to catch system exceptions you must edit the error event implementation properties.
To configure the implementation properties of an error event to catch system exceptions:
If you want to handle all the system exceptions that can occur while running this process, then select Catch All System Exceptions.
If you want to catch a specific business exception:
Click the Browse button next to the Exception field.
The Type dialog box appears.
Select Show System Faults.
The tree shows the available system faults. For a list of the supported exception for the different error events, see Table 18-1.
Enter the name of the exception or select it from the tree.
Click OK.
The Type dialog box closes and the selected exception appears in the Exception field.
You can only throw business exceptions using an error end event, thus only parent processes can catch these exceptions.
You can configure your process to throw custom high level exceptions instead of throwing the low-level exceptions that occur while running the task. To throw a high level exception, connect the boundary events in your activities to the end event that throws the error, or finish the subprocess event with an error end event.
You can use an error end event to configure your BPMN process to throw a business exception.
If you want to throw a custom exception, create a business exception.
You can also throw existing business exceptions or system exceptions.
See Section 18.6.3, "How to Create a Business Exception" for more information on how to create a business exception.
Identify the point in your process where you want to throw the exception.
Branch the flow of the process using one of these options:
Add a gateway to create a branch in the flow of the process.
Add a boundary event.
From the Component Palette, drag Error End Event and drop it in the process.
Add a sequence flow to link the gateway or boundary event, and the error end event.
Right-click the error end event.
Select Properties.
Click the Implementation tab.
Click the Browse button next to the Exception field.
The Type dialog box appears.
If you want to throw a system exception, Select Show System Faults.
The tree shows the available system faults. For a list of the supported exception for the different error events, see Table 18-1.
Enter the name of the exception or select it from the tree
Click OK.
The Type dialog box closes and the selected exception appears in the Exception field.
Click OK.
The BPMN Service Engine interrupts the process and throws the exception to the parent process. If the subprocess has an error catch boundary event attached or the parent process has an event subprocess that can handle the error event, then the parent process can handle the exception. Otherwise the parent process throws the exception to its parent process. If it does not have a parent process, then the BPMN Service Engine logs the exception to the Oracle Enterprise Manager fault handling system.
You can create a business exception and use it to implement the error events in your BPMN process.
To create a business exception:
Right-click a module in the Business Catalog.
If the business catalog does not contain a module, then you must create one.
Select New.
Select Exception.
Enter a name to identify the exception.
Click OK.
The Business Exception Editor opens.
Optionally, you can change the errorInfo attribute.
See Section 18.6.5, "How to Configure the ErrorInfo Attribute in a Business Exception" for information on how to modify the ErrorInfo attribute.
The exception appears in the business catalog in the module you selected. You can configure an error end event in your process to throw this exception, or you can configure a boundary error catch event to handle this exception.
Business exceptions contain an errorInfo attribute that you can use to store relevant information about the situation that caused the exception. You can use the information in this field to help users, process developers, and administrators understand the cause of the error.
To configure the ErrorInfo attribute in a business exception:
Open the Business Exception Editor.
In the Attributes section, expand the errorInfo attribute.
Make changes to the errorInfo attribute properties.
You can modify the following properties:
Description
Documentation
Type
Click Save or close the Business Exception Editor, and save the changes.
You can handle exceptions that occur in a subprocess in the same way you handle the exceptions in any other BPMN activity.
When a process communicates with another peer process, running any of the flow objects in the peer process may result in an error. For synchronic operations, the correct form of propagating these errors to the invoking peer process is using message events configured as errors.
A message event configured as an error communicates to the invoking peer process that an error occurred while running the process. However the audit trail indicates that the process ran successfully because this is an expected error.
You must define how the invoking peer process handles the exception using one of these options:
Add a boundary error catch event to the flow object that invokes the peer process.
Add an event subprocess that handles the exception to the invoking peer process.
If you do not handle the error in the invoking peer process, the error propagates and the process running does not complete successfully.
Note:
You must always define a path for the instance to follow if there are no error. If you do not define a path for the case where there are no errors the project does not build successfully.
Difference Between Using Error Events and Error Message Events
Using error end or throw events to handle errors during interprocess communication is not a good practice. You must only use error events for internal errors that might be handled within the process or propagated to the next level. These errors are not meaningful outside of this process.
The exceptions occurred while running a peer process do not propagate to the invoking peer process. Eventually the invoking peer process receives a time out notification because the peer process stopped responding.
If you know running an operation in a process that is used for inter-process communication may result in an error, it is advisable to add a message end or throw event to propagate the error to the invoking peer process.
The message error implementation requires you to select a business exception. If your project does not define business exceptions, then you must create a business exception. For more information about business exceptions, see Section 18.2, "Using Business Exceptions".
To handle errors in a peer process using message events:
Edit the peer BPMN process.
Add a message end or throw event.
Add a sequence flow from the flow object that can produce an error to the message end event.
Right-click the message end event.
Select Properties.
Click the Implementation tab.
From the Implementation list, select Exception.
Click the Browse button next to the Exception field, to browse the available business exceptions and select one.
Click OK.
If there is an error in the invoked peer process, the error is communicated to the process that invoked it. The invoking peer process must handle the error using error events or the error is propagated to the next level.
After running the invoked peer process, its status appears as successfully ran because the error message event is part of the expected flow of the process.
You can handle fault policy errors within a BPM process, treating them as a business exception.
To handle a fault policy in a BPM process:
Create an exception based on the wsdl file that contains the fault policy.
Add an error boundary catch event to the service task that can produce a fault policy error.
For more information on how to add a boundary event, see ...
Configure the error boundary catch event to catch the exception that represents the fault policy:
Right-click the error boundary catch event.
Select Properties.
Click the Browse button next to the Exception field.
Select the exception that represents the fault policy.
Click OK.
Click OK.
If you defined an exception to handle a fault policy error, then the BPMN Service Engine handles the fault policy error in the way you defined. When the fault policy error occurs in an activity then the instance follows the exception handling flow defined by the boundary error catch event.