Search icon CANCEL
Subscription
0
Cart icon
Your Cart (0 item)
Close icon
You have no products in your basket yet
Save more on your purchases! discount-offer-chevron-icon
Savings automatically calculated. No voucher code required.
Arrow left icon
Explore Products
Best Sellers
New Releases
Books
Videos
Audiobooks
Learning Hub
Free Learning
Arrow right icon
Arrow up icon
GO TO TOP
Oracle BPM Suite 12c Modeling Patterns

You're reading from   Oracle BPM Suite 12c Modeling Patterns Design and implement highly accurate Business Process Management solutions with Oracle BPM Patterns

Arrow left icon
Product type Paperback
Published in Sep 2014
Publisher Packt
ISBN-13 9781849689021
Length 454 pages
Edition 1st Edition
Languages
Arrow right icon
Author (1):
Arrow left icon
Vivek Acharya Vivek Acharya
Author Profile Icon Vivek Acharya
Vivek Acharya
Arrow right icon
View More author details
Toc

Table of Contents (12) Chapters Close

Preface 1. Flow Control Patterns 2. Multi-instance and State-based Patterns FREE CHAPTER 3. Invocation Patterns 4. Human Task Patterns 5. Interaction Patterns 6. Correlation Patterns 7. Exception Handling Patterns 8. Adaptive Case Management 9. Advanced Patterns A. Installing Oracle BPM Suite 12c Index

Conditional parallel split and parallel merge pattern

The conditional parallel split and parallel merge pattern is a part of advance branching and synchronization. It's similar to parallel split and merge; however, it is based on conditions, that is, it must follow a conditional transition. This process is shown in the following screenshot:

Conditional parallel split and parallel merge pattern

Let's consider an example scenario. When the token diverges at the first parallel gateway, it should perform conditional transition to different parallel tasks as follows:

  • ApprovalDeals should be performed only when effective discount is greater than 10 percent; otherwise, it should converge to the second parallel gateway without requesting for the deal's approval.
  • Similarly, we implement conditional parallel merge based on conditional transition. For the sake of example, let the equation of conditional transition be as follows:
    • Check customer status to find if it's a new or old customer. Converge to join at the parallel gateway. If the customer is old, you would not need an approval of deals; however, request for a deal's approval if the customer is new.
  • After TermsApproval, if the term approval request status is approved, then it converges at the join at the parallel gateway. Otherwise, the quote request can be ended, as shown in the preceding screenshot.

Working with conditional parallel split and merge

Oracle BPM does not have conditional transitions from the parallel gateway. If we try to implement a conditional transition outgoing from or incoming to a parallel gateway, it throws a Parallel Gateway cannot have outgoing Conditional Sequence Flows error . As we don't have a method to do conditional transition from the parallel gateway, we can still implement it in combination with the other gateway; in this case, it's the exclusive gateway (XOR). This scenario would be developed using parallel gateway in combination with exclusive gateway.

Download SalesQuoteProject from the download link for this chapter and open ConditionalParallelSplit&Merge. Check the configuration of the outgoing sequence flows from the parallel split point (ParallelSplit) and incoming sequence flow to the parallel merge gateway (ParallelSplit).

  1. Open EM console and test the ConditionalParallelSplit&Merge process using the ConditionalParallelSplit&Merge.xml test data available in the testsuites folder in the project.
  2. The test data contains the following data:

    Effective discount: 9

    Quote request status: Old

    Rest all fields can be user choice

  3. Log in to the Oracle BPM workspace as a salesrep user and approve the AcceptQuote task.
  4. Log in again to the BPM workspace as a fkafka user to approve the BusinessReview task.
  5. Process flow will reach the fork divergent parallel gateway (ParallelSplit) and would initiate the parallel flow to perform the DiscountCheck, ApproveDeals, and ApproveTerms task, as shown in the following screenshot:
    Working with conditional parallel split and merge
  6. As the effective discount is 9, which is less than 10 percent condition on the transition flow (<10%), the process will flow at the sequence flow (<10%) pathway and halts at parallel gateway (ParallelMerge) to get synchronized at the join convergence parallel gateway.
  7. Log in to the Oracle BPM workspace as a jstein user and approve the ApproveTerms task. Post approval, the token will get synchronized at the convergent point parallel gateway (ParallelMerge), and the process flow will move ahead.

A token gets created for each outgoing flow from the split parallel gateway, and none of the outgoing sequence flows are evaluated as the parallel gateway doesn't allow for outgoing conditional flow. However, we can use exclusive gateways to perform conditional transitions. This is not a direct offering of Oracle BPM; however, we can implement this using a combination of gateways. The parallel merge gateway waits for all the concurrent tokens to reach it. Until the concurrent tokens are not synchronized, multiple incoming sequence flows are blocked. Upon synchronization, one token is passed out of the merge gateway's outgoing flow.

Antipattern – the conditional parallel split and merge

In this section, we will demonstrate the fact that one cannot use conditional parallel split and merge by just merging some of the gateways. Process modeling needs to be performed meticulously. Hence, in this book, we are talking about patterns that offer techniques to solve repeatable issues and enhance the process modeling approach.

We will test the ConditionalParallelSplit&Merge process using the ConditionalParallelSplit&Merge.xml test data available in the testsuites folder in the project. However, this time, we will change the effective discount to any value greater than 10. Let the customer type be old, and keep all other fields as they are as follows:

  • Log in to the Oracle BPM workspace as the salesrep user and then as the fkafka user to approve the AcceptQuote and BusinessReview tasks.
  • Log in to the BPM workspace as the jstein user. It's the user to whom the ApproveTerms task is assigned. Log in and reject the task as follows:
    • The ApproveTerms task is now rejected, and the ConditionalParallelSplit&Merge process is modeled in such a way that if the ApproveTerms task is rejected, then the process should end. We can verify an outgoing sequence flow from the ApproveTerms task to the TermsOutcome exclusive gateway, which checks for task's outcome. If the outcome is REJECT, then the process should end.
  • Check Process Trace and Audit Trail in EM console as shown in the following screenshot. We will notice the following behavior:

    Once the ApproveTerms task is rejected, the process moves to the Terms Outcome exclusive gateway and then to the message end event of the process.

    However, we can check the process trace, as encircled in the following screenshot; the process is still running.

Now, if we log in to the BPM workspace as the jcooper user and approve the Approve Deals task, then only the parallel paths will converge, and the process will move ahead. This is demonstrated in the following screenshot:

Antipattern – the conditional parallel split and merge
lock icon The rest of the chapter is locked
Register for a free Packt account to unlock a world of extra content!
A free Packt account unlocks extra newsletters, articles, discounted offers, and much more. Start advancing your knowledge today.
Unlock this book and the full library FREE for 7 days
Get unlimited access to 7000+ expert-authored eBooks and videos courses covering every tech area you can think of
Renews at $19.99/month. Cancel anytime
Banner background image