SlideShare a Scribd company logo
1 of 40
BPEL Conformance
   in Open Source Engines
      Simon Harrer, Jörg Lenhard and Guido Wirtz
                Distributed Systems Group
                  University of Bamberg
                    Bamberg, Germany
{simon.harrer,joerg.lenhard,guido.wirtz}@uni-bamberg.de
Business
Process
Execution
Language
2.0
Source: Jens Rasch / pixelio.de
Travel Booking Service




   BPEL 2.0
BPEL 2.0
Open OASIS Standard; finalized in 2007
 De facto Standard for Orchestrations
      Used in many approaches
BPEL 2.0
Open OASIS Standard; finalized in 2007
 De facto Standard for Orchestrations
      Used in many approaches

    Fully Conformant Engines ensure
    - Portability
    - Avoidance of Vendor Lock-In
BPEL 2.0
Open OASIS Standard; finalized in 2007
 De facto Standard for Orchestrations
      Used in many approaches

    Fully Conformant Engines ensure
    - Portability
    - Avoidance of Vendor Lock-In

            Are we there, yet?
5 Open Source BPEL Engines
128 BPEL Test Cases


         10 Hours


640 Test Results
5 Open Source BPEL Engines
5 Open Source BPEL Engines


                             Apache ODE*
                             bpel-g**
                             OpenESB
                             Orchestra
                             Petals ESB
* Used in WSO2 Business Process Server, Intalio|BPMS and JBoss RiftSaw
** Based on ActiveBPEL, a previously commercial product of active endpoint
5 Open Source BPEL Engines



Apache ODE         Maintained
bpel-g
OpenESB            Latest Release
Orchestra
Petals ESB         Mature
5 Open Source BPEL Engines

     “BPEL 2.0 conformant”

Apache ODE         Maintained
bpel-g
OpenESB            Latest Release
Orchestra
Petals ESB         Mature
128 BPEL Test Cases
128 BPEL Test Cases
        BPEL
     Specification
128 BPEL Test Cases
                     BPEL
                  Specification



  basic                            structured
                     scopes
activities                          activities
Chapter 10         Chapter 12      Chapter 11
128 BPEL Test Cases
                      BPEL
                   Specification



  basic                                structured
                      scopes
activities                              activities

     Assign            EventHandlers          If


     Empty             FaultHandlers        While

       ….                   ….               ….
128 BPEL Test Cases
                      BPEL
                   Specification



  basic                                structured
                      scopes
activities                              activities

     Assign            EventHandlers          If


     Empty             FaultHandlers        While

       ….                   ….               ….
128 BPEL Test Cases
                                     While
<process>
   <partnerLinks />
   <variables />
   <sequence>
       <receive />
       <!−−MAIN EXTENSION POINT−−>
       <assign />
       <reply />
   </sequence>
</process>
128 BPEL Test Cases
                                         While
<process>
   <partnerLinks />
   <variables />
   <sequence>
       <receive />
       <assign name="InitializeLoopCounter">
           <!-- $Counter = 0 -->
       </assign>
       <while name="While">
          <condition>$Counter < $Input</condition>
           <assign name="IncrementLoopCounter“ >
              <!-- $Counter++ -->
           </assign>
       </while>
       <assign />
       <reply />
   </sequence>
</process>
128 BPEL Test Cases
                                             While
<process>
   <partnerLinks />
   <variables />
   <sequence>
       <receive />
       <assign name="InitializeLoopCounter">
           <!-- $Counter = 0 -->
       </assign>
       <while name="While">
          <condition>$Counter < $Input</condition>
           <assign name="IncrementLoopCounter“ >
              <!-- $Counter++ -->
           </assign>
       </while>
       <assign />
       <reply />
   </sequence>            Test       Input      Assertions
</process>                       synchronous: 5 output: 5
128 BPEL Test Cases
                                        tests
                             Assign      18
                             Empty        1
                                Exit      1
                             Invoke      11
                            Receive       5




 basic
                      ReceiveReply       11
                           Rethrow        3
                             Throw        5
                           Validate       2
                          Variables       3
                               Wait       3
                    Compensation          5
                   CorrelationSets        2
                    EventHandlers         8
 scopes



                     FaultHandlers        6
                MessageExchanges          3
                       PartnerLinks       1
                  Scope-Attributes        3
              TerminationHandlers         2
                          Variables       2
                               Flow       9
 structured




                           ForEach       10
                                   If     5
                                Pick      5
                       RepeatUntil        2
                         Sequence         1
                              While       1
128 BPEL Test Cases
                                       tests
                            Assign      18
                            Empty        1
                               Exit      1
                            Invoke      11
                           Receive       5      Quality Assurance
basic




                     ReceiveReply       11
                          Rethrow        3
                            Throw        5
                          Validate       2
                         Variables
                              Wait
                                         3
                                         3
                                                -   Permutate Configuration
                   Compensation
                  CorrelationSets
                                         5
                                         2      -   XML Schema Validation
                   EventHandlers
                                                -   Peer—Review in Group
                                         8
scopes




                    FaultHandlers        6
               MessageExchanges          3
                      PartnerLinks
                 Scope-Attributes
                                         1
                                         3      -   Publicly availability
                                                -   95% of Test Cases run
             TerminationHandlers         2
                         Variables       2
                              Flow       9

                                                    on at least one engine
structured




                          ForEach       10
                                  If     5
                               Pick      5
                      RepeatUntil        2
                        Sequence         1
                             While       1
10 Hours




           Source: Bernd Deschauer / pixelio.de
10 Hours

                                                                 Generate
                                                                 Reports

per engine and per test case
  Generate    Generate     Install    Start   Deploy   Execute     Stop
    BPEL        Test       Engine    Engine    BPEL      Test     Engine




  Prepare
  Folders
10 Hours

                                                                     Generate
                                                                     Reports

640 times = 5 engines * 128 test cases
  Generate    Generate      Install       Start   Deploy   Execute     Stop
    BPEL        Test        Engine       Engine    BPEL      Test     Engine




  Prepare
  Folders
10 Hours

                                                                     Generate
                                                                     Reports

640 times = 5 engines * 128 test cases
  Generate    Generate      Install       Start   Deploy   Execute     Stop
    BPEL        Test        Engine       Engine    BPEL      Test     Engine




  Prepare
  Folders                     8 hours
                         for test isolation
640 Test Results




               Source: S. Hofschlaeger / pixelio.de
640 Test Results

                         bpel-g


                         1
            Apache ODE


              2
                                   OpenESB


                                     3
Orchestra

  4
                                             PetalsESB

                                                5
640 Test Results         in %


                         bpel-g


            67 80
            Apache ODE
                                   OpenESB
Orchestra

                                    66
                                             PetalsESB

 49                                            24
640 Test Results                        in %
              bpel-g   Apache ODE   OpenESB   Orchestra    Petals ESB

  basic
activities78 60 54                             41           25
 scopes   78 78 84                             47           22
structured
          88 70 70
 activities                                    58           24
        Σ 80 67 66                             49           24
640 Test Results
                                                                                   •••••       100
                                                                                   ••••        75-99
                                                                                   •••         50-74
                                                                                   ••          1-49
                                                                                   •           0

                                       bpel-g   Apache ODE   OpenESB   Orchestra    Petals ESB
                            Assign        •••        •••        •••         ••            ••
                            Empty       •••••      •••••      •••••      •••••         •••••
                               Exit     •••••      •••••      •••••      •••••         •••••
                            Invoke        •••        •••         ••        •••            ••
                           Receive       ••••        •••         ••         ••            ••
basic




                     ReceiveReply         •••         ••         ••         ••            ••
                          Rethrow       •••••        •••         ••          •             •
                            Throw       •••••      •••••       ••••          •             •
                          Validate      •••••          •      •••••          •             •
                         Variables      •••••        •••        •••         ••            ••
                              Wait         ••      •••••      •••••        •••            ••
                   Compensation         •••••       ••••      •••••         ••             •
                  CorrelationSets       •••••      •••••        •••          •             •
                   EventHandlers           ••       ••••       ••••        •••             •
scopes




                    FaultHandlers       •••••      •••••      •••••         ••          ••••
               MessageExchanges         •••••         ••         ••         ••             •
                      PartnerLinks      •••••      •••••      •••••      •••••             •
                 Scope-Attributes       •••••        •••      •••••         ••           •••
             TerminationHandlers            •          •      •••••      •••••             •
                         Variables      •••••      •••••      •••••      •••••             •
                              Flow      •••••      •••••         ••       ••••             •
structured




                          ForEach        ••••         ••       ••••          •            ••
                                  If    •••••       ••••       ••••       ••••          ••••
                               Pick       •••      •••••       ••••       ••••            ••
                      RepeatUntil       •••••        •••      •••••      •••••             •
                        Sequence        •••••      •••••      •••••      •••••         •••••
                             While      •••••      •••••      •••••      •••••         •••••
Portability ?
0,8



      0,59

             0,45


                      0,25
                             0,15



1      2      3        4      5
Portability ?
0,8



      0,59

             0,45


                      0,25
                             0,15



1      2      3        4      5
5 Open Source BPEL Engines
128 BPEL Test Cases


         10 Hours


640 Test Results
5 Open Source BPEL Engines
128 BPEL Test Cases


         10 Hours


640 Test Results
     Limited Portability
Source: Karl Dichtler / pixelio.de
5 BPEL Engines
128 BPEL Test Cases


        10 Hours


640 Test Results
5 BPEL Engines
128 BPEL Test Cases


        10 Hours


640 Test Results
5 BPEL Engines
128 BPEL Test Cases


        10 Hours


640 Test Results
Try it!
Web Site    https://github.com/uniba-dsg/betsy/
Source Code https://github.com/uniba-dsg/betsy/tree/soca-2012




We ♥ Feedback

More Related Content

Recently uploaded

A Year of the Servo Reboot: Where Are We Now?
A Year of the Servo Reboot: Where Are We Now?A Year of the Servo Reboot: Where Are We Now?
A Year of the Servo Reboot: Where Are We Now?Igalia
 
Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...
Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...
Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...apidays
 
Axa Assurance Maroc - Insurer Innovation Award 2024
Axa Assurance Maroc - Insurer Innovation Award 2024Axa Assurance Maroc - Insurer Innovation Award 2024
Axa Assurance Maroc - Insurer Innovation Award 2024The Digital Insurer
 
Apidays New York 2024 - The value of a flexible API Management solution for O...
Apidays New York 2024 - The value of a flexible API Management solution for O...Apidays New York 2024 - The value of a flexible API Management solution for O...
Apidays New York 2024 - The value of a flexible API Management solution for O...apidays
 
FWD Group - Insurer Innovation Award 2024
FWD Group - Insurer Innovation Award 2024FWD Group - Insurer Innovation Award 2024
FWD Group - Insurer Innovation Award 2024The Digital Insurer
 
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers:  A Deep Dive into Serverless Spatial Data and FMECloud Frontiers:  A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FMESafe Software
 
MS Copilot expands with MS Graph connectors
MS Copilot expands with MS Graph connectorsMS Copilot expands with MS Graph connectors
MS Copilot expands with MS Graph connectorsNanddeep Nachan
 
Why Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire businessWhy Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire businesspanagenda
 
Emergent Methods: Multi-lingual narrative tracking in the news - real-time ex...
Emergent Methods: Multi-lingual narrative tracking in the news - real-time ex...Emergent Methods: Multi-lingual narrative tracking in the news - real-time ex...
Emergent Methods: Multi-lingual narrative tracking in the news - real-time ex...Zilliz
 
Apidays New York 2024 - The Good, the Bad and the Governed by David O'Neill, ...
Apidays New York 2024 - The Good, the Bad and the Governed by David O'Neill, ...Apidays New York 2024 - The Good, the Bad and the Governed by David O'Neill, ...
Apidays New York 2024 - The Good, the Bad and the Governed by David O'Neill, ...apidays
 
Real Time Object Detection Using Open CV
Real Time Object Detection Using Open CVReal Time Object Detection Using Open CV
Real Time Object Detection Using Open CVKhem
 
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...Jeffrey Haguewood
 
MINDCTI Revenue Release Quarter One 2024
MINDCTI Revenue Release Quarter One 2024MINDCTI Revenue Release Quarter One 2024
MINDCTI Revenue Release Quarter One 2024MIND CTI
 
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, AdobeApidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobeapidays
 
Strategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
Strategize a Smooth Tenant-to-tenant Migration and Copilot TakeoffStrategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
Strategize a Smooth Tenant-to-tenant Migration and Copilot Takeoffsammart93
 
GenAI Risks & Security Meetup 01052024.pdf
GenAI Risks & Security Meetup 01052024.pdfGenAI Risks & Security Meetup 01052024.pdf
GenAI Risks & Security Meetup 01052024.pdflior mazor
 
Manulife - Insurer Transformation Award 2024
Manulife - Insurer Transformation Award 2024Manulife - Insurer Transformation Award 2024
Manulife - Insurer Transformation Award 2024The Digital Insurer
 
How to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected WorkerHow to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected WorkerThousandEyes
 
Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...
Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...
Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...apidays
 

Recently uploaded (20)

A Year of the Servo Reboot: Where Are We Now?
A Year of the Servo Reboot: Where Are We Now?A Year of the Servo Reboot: Where Are We Now?
A Year of the Servo Reboot: Where Are We Now?
 
Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...
Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...
Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...
 
Axa Assurance Maroc - Insurer Innovation Award 2024
Axa Assurance Maroc - Insurer Innovation Award 2024Axa Assurance Maroc - Insurer Innovation Award 2024
Axa Assurance Maroc - Insurer Innovation Award 2024
 
Apidays New York 2024 - The value of a flexible API Management solution for O...
Apidays New York 2024 - The value of a flexible API Management solution for O...Apidays New York 2024 - The value of a flexible API Management solution for O...
Apidays New York 2024 - The value of a flexible API Management solution for O...
 
FWD Group - Insurer Innovation Award 2024
FWD Group - Insurer Innovation Award 2024FWD Group - Insurer Innovation Award 2024
FWD Group - Insurer Innovation Award 2024
 
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers:  A Deep Dive into Serverless Spatial Data and FMECloud Frontiers:  A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
 
MS Copilot expands with MS Graph connectors
MS Copilot expands with MS Graph connectorsMS Copilot expands with MS Graph connectors
MS Copilot expands with MS Graph connectors
 
Why Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire businessWhy Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire business
 
Emergent Methods: Multi-lingual narrative tracking in the news - real-time ex...
Emergent Methods: Multi-lingual narrative tracking in the news - real-time ex...Emergent Methods: Multi-lingual narrative tracking in the news - real-time ex...
Emergent Methods: Multi-lingual narrative tracking in the news - real-time ex...
 
Apidays New York 2024 - The Good, the Bad and the Governed by David O'Neill, ...
Apidays New York 2024 - The Good, the Bad and the Governed by David O'Neill, ...Apidays New York 2024 - The Good, the Bad and the Governed by David O'Neill, ...
Apidays New York 2024 - The Good, the Bad and the Governed by David O'Neill, ...
 
Real Time Object Detection Using Open CV
Real Time Object Detection Using Open CVReal Time Object Detection Using Open CV
Real Time Object Detection Using Open CV
 
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...
 
MINDCTI Revenue Release Quarter One 2024
MINDCTI Revenue Release Quarter One 2024MINDCTI Revenue Release Quarter One 2024
MINDCTI Revenue Release Quarter One 2024
 
+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
 
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, AdobeApidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
 
Strategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
Strategize a Smooth Tenant-to-tenant Migration and Copilot TakeoffStrategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
Strategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
 
GenAI Risks & Security Meetup 01052024.pdf
GenAI Risks & Security Meetup 01052024.pdfGenAI Risks & Security Meetup 01052024.pdf
GenAI Risks & Security Meetup 01052024.pdf
 
Manulife - Insurer Transformation Award 2024
Manulife - Insurer Transformation Award 2024Manulife - Insurer Transformation Award 2024
Manulife - Insurer Transformation Award 2024
 
How to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected WorkerHow to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected Worker
 
Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...
Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...
Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...
 

Featured

2024 State of Marketing Report – by Hubspot
2024 State of Marketing Report – by Hubspot2024 State of Marketing Report – by Hubspot
2024 State of Marketing Report – by HubspotMarius Sescu
 
Everything You Need To Know About ChatGPT
Everything You Need To Know About ChatGPTEverything You Need To Know About ChatGPT
Everything You Need To Know About ChatGPTExpeed Software
 
Product Design Trends in 2024 | Teenage Engineerings
Product Design Trends in 2024 | Teenage EngineeringsProduct Design Trends in 2024 | Teenage Engineerings
Product Design Trends in 2024 | Teenage EngineeringsPixeldarts
 
How Race, Age and Gender Shape Attitudes Towards Mental Health
How Race, Age and Gender Shape Attitudes Towards Mental HealthHow Race, Age and Gender Shape Attitudes Towards Mental Health
How Race, Age and Gender Shape Attitudes Towards Mental HealthThinkNow
 
AI Trends in Creative Operations 2024 by Artwork Flow.pdf
AI Trends in Creative Operations 2024 by Artwork Flow.pdfAI Trends in Creative Operations 2024 by Artwork Flow.pdf
AI Trends in Creative Operations 2024 by Artwork Flow.pdfmarketingartwork
 
PEPSICO Presentation to CAGNY Conference Feb 2024
PEPSICO Presentation to CAGNY Conference Feb 2024PEPSICO Presentation to CAGNY Conference Feb 2024
PEPSICO Presentation to CAGNY Conference Feb 2024Neil Kimberley
 
Content Methodology: A Best Practices Report (Webinar)
Content Methodology: A Best Practices Report (Webinar)Content Methodology: A Best Practices Report (Webinar)
Content Methodology: A Best Practices Report (Webinar)contently
 
How to Prepare For a Successful Job Search for 2024
How to Prepare For a Successful Job Search for 2024How to Prepare For a Successful Job Search for 2024
How to Prepare For a Successful Job Search for 2024Albert Qian
 
Social Media Marketing Trends 2024 // The Global Indie Insights
Social Media Marketing Trends 2024 // The Global Indie InsightsSocial Media Marketing Trends 2024 // The Global Indie Insights
Social Media Marketing Trends 2024 // The Global Indie InsightsKurio // The Social Media Age(ncy)
 
Trends In Paid Search: Navigating The Digital Landscape In 2024
Trends In Paid Search: Navigating The Digital Landscape In 2024Trends In Paid Search: Navigating The Digital Landscape In 2024
Trends In Paid Search: Navigating The Digital Landscape In 2024Search Engine Journal
 
5 Public speaking tips from TED - Visualized summary
5 Public speaking tips from TED - Visualized summary5 Public speaking tips from TED - Visualized summary
5 Public speaking tips from TED - Visualized summarySpeakerHub
 
ChatGPT and the Future of Work - Clark Boyd
ChatGPT and the Future of Work - Clark Boyd ChatGPT and the Future of Work - Clark Boyd
ChatGPT and the Future of Work - Clark Boyd Clark Boyd
 
Getting into the tech field. what next
Getting into the tech field. what next Getting into the tech field. what next
Getting into the tech field. what next Tessa Mero
 
Google's Just Not That Into You: Understanding Core Updates & Search Intent
Google's Just Not That Into You: Understanding Core Updates & Search IntentGoogle's Just Not That Into You: Understanding Core Updates & Search Intent
Google's Just Not That Into You: Understanding Core Updates & Search IntentLily Ray
 
Time Management & Productivity - Best Practices
Time Management & Productivity -  Best PracticesTime Management & Productivity -  Best Practices
Time Management & Productivity - Best PracticesVit Horky
 
The six step guide to practical project management
The six step guide to practical project managementThe six step guide to practical project management
The six step guide to practical project managementMindGenius
 
Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...
Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...
Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...RachelPearson36
 

Featured (20)

2024 State of Marketing Report – by Hubspot
2024 State of Marketing Report – by Hubspot2024 State of Marketing Report – by Hubspot
2024 State of Marketing Report – by Hubspot
 
Everything You Need To Know About ChatGPT
Everything You Need To Know About ChatGPTEverything You Need To Know About ChatGPT
Everything You Need To Know About ChatGPT
 
Product Design Trends in 2024 | Teenage Engineerings
Product Design Trends in 2024 | Teenage EngineeringsProduct Design Trends in 2024 | Teenage Engineerings
Product Design Trends in 2024 | Teenage Engineerings
 
How Race, Age and Gender Shape Attitudes Towards Mental Health
How Race, Age and Gender Shape Attitudes Towards Mental HealthHow Race, Age and Gender Shape Attitudes Towards Mental Health
How Race, Age and Gender Shape Attitudes Towards Mental Health
 
AI Trends in Creative Operations 2024 by Artwork Flow.pdf
AI Trends in Creative Operations 2024 by Artwork Flow.pdfAI Trends in Creative Operations 2024 by Artwork Flow.pdf
AI Trends in Creative Operations 2024 by Artwork Flow.pdf
 
Skeleton Culture Code
Skeleton Culture CodeSkeleton Culture Code
Skeleton Culture Code
 
PEPSICO Presentation to CAGNY Conference Feb 2024
PEPSICO Presentation to CAGNY Conference Feb 2024PEPSICO Presentation to CAGNY Conference Feb 2024
PEPSICO Presentation to CAGNY Conference Feb 2024
 
Content Methodology: A Best Practices Report (Webinar)
Content Methodology: A Best Practices Report (Webinar)Content Methodology: A Best Practices Report (Webinar)
Content Methodology: A Best Practices Report (Webinar)
 
How to Prepare For a Successful Job Search for 2024
How to Prepare For a Successful Job Search for 2024How to Prepare For a Successful Job Search for 2024
How to Prepare For a Successful Job Search for 2024
 
Social Media Marketing Trends 2024 // The Global Indie Insights
Social Media Marketing Trends 2024 // The Global Indie InsightsSocial Media Marketing Trends 2024 // The Global Indie Insights
Social Media Marketing Trends 2024 // The Global Indie Insights
 
Trends In Paid Search: Navigating The Digital Landscape In 2024
Trends In Paid Search: Navigating The Digital Landscape In 2024Trends In Paid Search: Navigating The Digital Landscape In 2024
Trends In Paid Search: Navigating The Digital Landscape In 2024
 
5 Public speaking tips from TED - Visualized summary
5 Public speaking tips from TED - Visualized summary5 Public speaking tips from TED - Visualized summary
5 Public speaking tips from TED - Visualized summary
 
ChatGPT and the Future of Work - Clark Boyd
ChatGPT and the Future of Work - Clark Boyd ChatGPT and the Future of Work - Clark Boyd
ChatGPT and the Future of Work - Clark Boyd
 
Getting into the tech field. what next
Getting into the tech field. what next Getting into the tech field. what next
Getting into the tech field. what next
 
Google's Just Not That Into You: Understanding Core Updates & Search Intent
Google's Just Not That Into You: Understanding Core Updates & Search IntentGoogle's Just Not That Into You: Understanding Core Updates & Search Intent
Google's Just Not That Into You: Understanding Core Updates & Search Intent
 
How to have difficult conversations
How to have difficult conversations How to have difficult conversations
How to have difficult conversations
 
Introduction to Data Science
Introduction to Data ScienceIntroduction to Data Science
Introduction to Data Science
 
Time Management & Productivity - Best Practices
Time Management & Productivity -  Best PracticesTime Management & Productivity -  Best Practices
Time Management & Productivity - Best Practices
 
The six step guide to practical project management
The six step guide to practical project managementThe six step guide to practical project management
The six step guide to practical project management
 
Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...
Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...
Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...
 

BPEL Conformance in Open Source Engines

  • 1. BPEL Conformance in Open Source Engines Simon Harrer, Jörg Lenhard and Guido Wirtz Distributed Systems Group University of Bamberg Bamberg, Germany {simon.harrer,joerg.lenhard,guido.wirtz}@uni-bamberg.de
  • 3. Source: Jens Rasch / pixelio.de
  • 5. BPEL 2.0 Open OASIS Standard; finalized in 2007 De facto Standard for Orchestrations Used in many approaches
  • 6. BPEL 2.0 Open OASIS Standard; finalized in 2007 De facto Standard for Orchestrations Used in many approaches Fully Conformant Engines ensure - Portability - Avoidance of Vendor Lock-In
  • 7. BPEL 2.0 Open OASIS Standard; finalized in 2007 De facto Standard for Orchestrations Used in many approaches Fully Conformant Engines ensure - Portability - Avoidance of Vendor Lock-In Are we there, yet?
  • 8. 5 Open Source BPEL Engines 128 BPEL Test Cases 10 Hours 640 Test Results
  • 9. 5 Open Source BPEL Engines
  • 10. 5 Open Source BPEL Engines Apache ODE* bpel-g** OpenESB Orchestra Petals ESB * Used in WSO2 Business Process Server, Intalio|BPMS and JBoss RiftSaw ** Based on ActiveBPEL, a previously commercial product of active endpoint
  • 11. 5 Open Source BPEL Engines Apache ODE Maintained bpel-g OpenESB Latest Release Orchestra Petals ESB Mature
  • 12. 5 Open Source BPEL Engines “BPEL 2.0 conformant” Apache ODE Maintained bpel-g OpenESB Latest Release Orchestra Petals ESB Mature
  • 13. 128 BPEL Test Cases
  • 14. 128 BPEL Test Cases BPEL Specification
  • 15. 128 BPEL Test Cases BPEL Specification basic structured scopes activities activities Chapter 10 Chapter 12 Chapter 11
  • 16. 128 BPEL Test Cases BPEL Specification basic structured scopes activities activities Assign EventHandlers If Empty FaultHandlers While …. …. ….
  • 17. 128 BPEL Test Cases BPEL Specification basic structured scopes activities activities Assign EventHandlers If Empty FaultHandlers While …. …. ….
  • 18. 128 BPEL Test Cases While <process> <partnerLinks /> <variables /> <sequence> <receive /> <!−−MAIN EXTENSION POINT−−> <assign /> <reply /> </sequence> </process>
  • 19. 128 BPEL Test Cases While <process> <partnerLinks /> <variables /> <sequence> <receive /> <assign name="InitializeLoopCounter"> <!-- $Counter = 0 --> </assign> <while name="While"> <condition>$Counter < $Input</condition> <assign name="IncrementLoopCounter“ > <!-- $Counter++ --> </assign> </while> <assign /> <reply /> </sequence> </process>
  • 20. 128 BPEL Test Cases While <process> <partnerLinks /> <variables /> <sequence> <receive /> <assign name="InitializeLoopCounter"> <!-- $Counter = 0 --> </assign> <while name="While"> <condition>$Counter < $Input</condition> <assign name="IncrementLoopCounter“ > <!-- $Counter++ --> </assign> </while> <assign /> <reply /> </sequence> Test Input Assertions </process> synchronous: 5 output: 5
  • 21. 128 BPEL Test Cases tests Assign 18 Empty 1 Exit 1 Invoke 11 Receive 5 basic ReceiveReply 11 Rethrow 3 Throw 5 Validate 2 Variables 3 Wait 3 Compensation 5 CorrelationSets 2 EventHandlers 8 scopes FaultHandlers 6 MessageExchanges 3 PartnerLinks 1 Scope-Attributes 3 TerminationHandlers 2 Variables 2 Flow 9 structured ForEach 10 If 5 Pick 5 RepeatUntil 2 Sequence 1 While 1
  • 22. 128 BPEL Test Cases tests Assign 18 Empty 1 Exit 1 Invoke 11 Receive 5 Quality Assurance basic ReceiveReply 11 Rethrow 3 Throw 5 Validate 2 Variables Wait 3 3 - Permutate Configuration Compensation CorrelationSets 5 2 - XML Schema Validation EventHandlers - Peer—Review in Group 8 scopes FaultHandlers 6 MessageExchanges 3 PartnerLinks Scope-Attributes 1 3 - Publicly availability - 95% of Test Cases run TerminationHandlers 2 Variables 2 Flow 9 on at least one engine structured ForEach 10 If 5 Pick 5 RepeatUntil 2 Sequence 1 While 1
  • 23. 10 Hours Source: Bernd Deschauer / pixelio.de
  • 24. 10 Hours Generate Reports per engine and per test case Generate Generate Install Start Deploy Execute Stop BPEL Test Engine Engine BPEL Test Engine Prepare Folders
  • 25. 10 Hours Generate Reports 640 times = 5 engines * 128 test cases Generate Generate Install Start Deploy Execute Stop BPEL Test Engine Engine BPEL Test Engine Prepare Folders
  • 26. 10 Hours Generate Reports 640 times = 5 engines * 128 test cases Generate Generate Install Start Deploy Execute Stop BPEL Test Engine Engine BPEL Test Engine Prepare Folders 8 hours for test isolation
  • 27. 640 Test Results Source: S. Hofschlaeger / pixelio.de
  • 28. 640 Test Results bpel-g 1 Apache ODE 2 OpenESB 3 Orchestra 4 PetalsESB 5
  • 29. 640 Test Results in % bpel-g 67 80 Apache ODE OpenESB Orchestra 66 PetalsESB 49 24
  • 30. 640 Test Results in % bpel-g Apache ODE OpenESB Orchestra Petals ESB basic activities78 60 54 41 25 scopes 78 78 84 47 22 structured 88 70 70 activities 58 24 Σ 80 67 66 49 24
  • 31. 640 Test Results ••••• 100 •••• 75-99 ••• 50-74 •• 1-49 • 0 bpel-g Apache ODE OpenESB Orchestra Petals ESB Assign ••• ••• ••• •• •• Empty ••••• ••••• ••••• ••••• ••••• Exit ••••• ••••• ••••• ••••• ••••• Invoke ••• ••• •• ••• •• Receive •••• ••• •• •• •• basic ReceiveReply ••• •• •• •• •• Rethrow ••••• ••• •• • • Throw ••••• ••••• •••• • • Validate ••••• • ••••• • • Variables ••••• ••• ••• •• •• Wait •• ••••• ••••• ••• •• Compensation ••••• •••• ••••• •• • CorrelationSets ••••• ••••• ••• • • EventHandlers •• •••• •••• ••• • scopes FaultHandlers ••••• ••••• ••••• •• •••• MessageExchanges ••••• •• •• •• • PartnerLinks ••••• ••••• ••••• ••••• • Scope-Attributes ••••• ••• ••••• •• ••• TerminationHandlers • • ••••• ••••• • Variables ••••• ••••• ••••• ••••• • Flow ••••• ••••• •• •••• • structured ForEach •••• •• •••• • •• If ••••• •••• •••• •••• •••• Pick ••• ••••• •••• •••• •• RepeatUntil ••••• ••• ••••• ••••• • Sequence ••••• ••••• ••••• ••••• ••••• While ••••• ••••• ••••• ••••• •••••
  • 32. Portability ? 0,8 0,59 0,45 0,25 0,15 1 2 3 4 5
  • 33. Portability ? 0,8 0,59 0,45 0,25 0,15 1 2 3 4 5
  • 34. 5 Open Source BPEL Engines 128 BPEL Test Cases 10 Hours 640 Test Results
  • 35. 5 Open Source BPEL Engines 128 BPEL Test Cases 10 Hours 640 Test Results Limited Portability
  • 36. Source: Karl Dichtler / pixelio.de
  • 37. 5 BPEL Engines 128 BPEL Test Cases 10 Hours 640 Test Results
  • 38. 5 BPEL Engines 128 BPEL Test Cases 10 Hours 640 Test Results
  • 39. 5 BPEL Engines 128 BPEL Test Cases 10 Hours 640 Test Results
  • 40. Try it! Web Site https://github.com/uniba-dsg/betsy/ Source Code https://github.com/uniba-dsg/betsy/tree/soca-2012 We ♥ Feedback