[Date Prev] | [Thread Prev] | [Thread Next] | [Date Next] -- [Date Index] | [Thread Index] | [List Home]
Subject: Re: [wsbpel] Issue 6 - Rough draft of proposal for vote
i assume that the leaf scopes are serializable and that's why they're there? Yaron Y. Goland wrote: > Below is an example of 2 out of 3, it is generalizable from there. > > scope > variables > variable name="counter" type="xs:int" > sequence > assign > copy > from literal="true" > "0" > to > $counter > flow > scope > ... > assign > copy > from > $counter + 1 > to > $counter > switch > case > condition > $counter >= 2 > break > scope > ... > assign > copy > from > $counter + 1 > to > $counter > switch > case > condition > $counter >= 2 > break > scope > ... > assign > copy > from > $counter + 1 > to > $counter > switch > case > condition > $counter >= 2 > break > > > Trickovic, Ivana wrote: > >> >> >> Yaron, >> >> Would you illustrate how break activity could be used? How does it >> resolve problems tackled by proposals we have on table at the moment? >> >> Regards, >> >> Ivana >> >> > -----Original Message----- >> > From: Yaron Y. Goland [mailto:ygoland@bea.com] >> > Sent: Dienstag, 14. September 2004 00:01 >> > To: Alex Yiu >> > Cc: Trickovic, Ivana; Axel Martens; Frank Leymann; Dieter >> > Roller; Dieter >> > Koenig1; edwink@collaxa.com; satisht@microsoft.com; >> > wsbpel@lists.oasis-open.org >> > Subject: Re: [wsbpel] Issue 6 - Rough draft of proposal for vote >> > >> > >> > I believe that the complexity of the current proposal is well >> > above the >> > capabilities of what I expect to be the average BPEL programmer. >> > Completion conditions, ignorable faults, new XPATH functions, etc. >> > introduces a lot of complexity that I believe that average BPEL >> > programmer would not be interested in dealing with. >> > >> > We know from many decades of language experience that average >> > programmers can deal with break/continue. I know from at >> > least our own >> > experience at BEA that users can deal with the concept of a >> > flow where a >> > break in the flow results in the other members of the flow being >> > terminated in the BPEL meaning of the term. >> > >> > Defining a break activity and specifying that if break is used in the >> > context of flow then this means that the flow activity ends and any >> > uncompleted members of the flow are terminated would both fit >> > directly >> > into BPEL's existing syntax and semantics and I believe be >> > simple enough >> > that the average programmer can handle it. I would therefore >> > offer break >> > (and it's relative 'continue') as an alternative. >> > >> > Thanks, >> > >> > Yaron >> > >> > Alex Yiu wrote: >> > >> > > >> > > Hi, >> > > >> > > Ivana, thanks for sending out this proposal. >> > > I believe a number of us (including me) like the >> > <completionConditon> >> > > construct from your proposal high level speaking. >> > > >> > > After reading the proposal, I guess we need to work on a number of >> > > details. I would like to ask a few questions / mention a few >> points: >> > > >> > > * Minor syntax and semantics questions : >> > > o Do we want to allow expression for branch >> > attribute? instead >> > > of just a constant integer? >> > > o We may need to some minor syntax adjustment for >> > expression >> > > attribute because we have passed Isseu 13 already. >> > > o If answers to the above question are yes, then >> > the condition >> > > syntax may become a choice (xsd:choice) of the >> > following two: >> > > <condition >> > > > >> expressionLanguage="anyURI"?>boolean-expression</condition> >> > > <branchCondition >> > > > >> expressionLanguage="anyURI"?>integer-expression</condition> >> > > >> > > * About completionConditionFailure : it looks like a >> > nice idea so >> > > far ... >> > > >> > > * About the new "isCompleted()" function : I am not >> > against this >> > > function. But, I tend to think there are usually BPEL >> > variables >> > > being modifed as the execution result of a flow >> > activity. (See the >> > > train-or-plane-and-hotel example). Is it more typical to have >> > > completionCondition to be evaluated on those variables? >> > > Also, after the completion of the whole flow, it is >> > not uncommon >> > > for people to have logic to find out which branch is finished >> > > (especially when "or" is involved in the condition). The >> > > "isComplete()" function would be available only within the >> > > completionCondition within the flow. People may get >> > confused and >> > > attempt to use the "isComplete()" function outside >> > the flow. If >> > > the completionCondition relies on variables, the same >> logic is >> > > applicable outside of the flow. >> > > >> > > * About the IgnoreFault semantics: I recall this >> > ignoreFault idea >> > > back to March F2F. With ignoreFault semantics, it essentially >> > > introduces two brand new semantics. >> > > o It turns <flow> into a semi-<scope> like construct >> > > o It adds this new "ignoreFault" semantics: which catches >> > > certain fault and the catching action will not cause >> any >> > > scope to be marked as faulted. >> > > >> > > I tend to think this "ignoreFault" functionality has >> > quite a heavy >> > > weight impact to <flow> and fault handling picture in >> > BPEL. If there >> > > is an alternative way to achieve similar business >> > logic, I would go >> > > for the alternative way. >> > > >> > > Quoted from Ivana's email: >> > > " Not all activities must complete in order the enclosing flow >> > > activity to complete. The way to identify that an >> > enclosed activity >> > > did not complete is to propagate faults. " >> > > >> > > I agree with the first sentence. But, I am not sure >> > that propagating >> > > fault is the only way to identify an enclosed activity did not >> > > complete. I would rather use a scope as an activity enclosed by >> > > flow. If we wish to suppress any minor fault which >> > happens during >> > > the execution of the scope, then we can just add a >> > fault handler. If >> > > the fault that happen, the scope will be marked as "faulted". >> > > >> > > The completeConditon can identify the "incomplete" state of the >> > > scope by two ways: >> > > >> > > * completeCondition can be evaluated based on BPEL >> > variables, >> > > which are set to "incomplete" state by pre-flow >> > initialization >> > > or related fault-handler logic. >> > > * branch-based condition will interprete a faulted scope as >> > > "incomplete" branch and will not count them into >> > the required >> > > N branches. >> > > >> > > This will allow us to suppress minor fault with or without the >> > > <completionCondition> construct. Please see the >> > following example. >> > > It is already legal and working today. It shows how to suppress >> > > "foo:barFault" without the <completeCondition> construct >> > > >> > > <flow> >> > > <scope name="A"> >> > > <faultHandler> >> > > <catch faultName="foo:barFault" ... > ... </catch> >> > > </faultHandler> >> > > <sequence> >> > > ... <invoke name="doA" ... /> ... >> > > </sequence> >> > > </scope> >> > > <scope name="B"> ... <!-- similar to A --> ... </scope> >> > > </flow> >> > > >> > > If the invoke of "doA" triggers "foo:barFault", the >> > scope "A" will >> > > be marked as faulted. On the other hand, scope "B" will >> > be allowed >> > > to continue and complete. After scope "B" is completed, the >> > > compensation handler of scope "B" will be installed. And, the >> > > overall execution of flow is still considered a normal >> > completion. >> > > >> > > I hope I have illustrated we can achieve similar logic without >> > > introducing a new "ignoreFault" construct and concept to BPEL. >> > > >> > > What "completionCondition" does should be just >> > providing a way to >> > > pro-actively cancel/terminate other flows without >> > waiting to them to >> > > complete or to be faulted. >> > > >> > > * About "Cancel-other-flows": (Let me consolidate what I am >> > > leaning towards so far.) We need to formal define the >> > notion of a >> > > " cancel-other-flows " mechanism. This mechanism is >> > specified and >> > > attached to <flow> construct (and future parallel forEach >> > > construct). When this mechanism is triggered by one >> > of parallel >> > > flows, it will cancel/terminate other parallel flows which >> are >> > > still running, after the triggering flow is completed. If the >> > > other flow activties are scope activities, the scope will be >> > > marked as cancelled. >> > > >> > > This mechanism will be triggered upon the >> > completionCondition is >> > > evaluated to be true. >> > > >> > > [Note: (a) since this mechanism is triggered by >> > without using any >> > > fault directly. This will again decrease the need of >> > "ignoreFault" >> > > construct (b) This mechanism will affect the wordings >> > of Issue 135 >> > > to an extent.] >> > > >> > > [Question: again, should we enforce scope-only activity when >> > > completionCondition is used? I tend to say yes.] >> > > >> > > >> > > >> > > Thank you all for following and reading this email thread!!! >> > > >> > > >> > > >> > > Regards, >> > > Alex Yiu >> > > > > >> > > >> > > Trickovic, Ivana wrote: >> > > >> > >> > >> >> > >> Here is a proposal for the completion condition - it >> > addresses some >> > >> issues not tackled so far (at least not in case of >> > >> <completeCondition>). It is a version of the proposal for >> > completion >> > >> condition for the bundle element. This proposal includes >> > comments from >> > >> many people including Frank Leymann, Dieter Koenig, Dieter >> > Roller and >> > >> Satish Thatte. It does not mean that they completely support the >> > >> proposal - they may have issues with any part of the proposal. >> > >> >> > >> > >> >> > >> > >> >> > >> Completion condition >> > >> >> > >> ===================== >> > >> >> > >> The current semantics of the flow activity is that it >> > waits for all >> > >> concurrent activities to complete. The completion also >> > means that an >> > >> enclosed activity/scope may end abnormally or be skipped (e.g. the >> > >> join condition of the activity evaluated to false). If a fault is >> > >> thrown within an enclosed activity/scope and one of the >> > local fault >> > >> handlers catch the fault (and does not rethrow the fault), the >> > >> enclosed activity/scope will be deemed to be completed >> > (although ended >> > >> abnormally). If a fault is not caught by any local fault >> > handler (or >> > >> is rethrown) the flow activity will terminate all active >> > concurrent >> > >> activities and corresponding fault handler may be initiated. >> > >> >> > >> > >> >> > >> A completion condition for the flow activity is needed for >> > scenarios >> > >> where not all concurrent activities of a flow activity >> > must complete >> > >> in order the flow activity to complete. Note: We are not >> > talking about >> > >> "successful completion" of enclosed concurrent activities >> > because that >> > >> would not be consistent with the semantics of the current >> > flow activity. >> > >> >> > >> > >> >> > >> The completion condition may have different flavors, such as: >> > >> >> > >> (1) N out of M >> > >> >> > >> (2) The two most important requests completed >> > >> >> > >> (3) A Boolean condition operating upon process variables >> > >> >> > >> > >> >> > >> Not all activities must complete in order the enclosing >> > flow activity >> > >> to complete. The way to identify that an enclosed activity did not >> > >> complete is to propagate faults. We may distinguish between severe >> > >> faults and those that can be ignored. Severe faults cause the >> > >> enclosing flow activity (or more precisely, enclosing scope) to >> > >> terminate the flow activity, including all active concurrent >> > >> activities, and corresponding fault handler may be >> > initiated. Other >> > >> faults may be ignored - the flow activity is "informed" that a >> > >> concurrent activity did not complete but still allows other active >> > >> concurrent activities to continue with execution. >> > >> >> > >> > >> >> > >> Ignore semantics >> > >> >> > >> ================= >> > >> >> > >> Faults thrown within enclosed concurrent activities/scopes and not >> > >> handled by local fault handlers are rethrown. Enclosing >> > <flow> element >> > >> decides which of these rethrown faults can be ignored. This new >> > >> "ignore" semantics should be part of the completion condition and >> > >> should apply to all enclosed activities. This new >> > semantics does not >> > >> introduce a new fault handling mechanism. It is needed for >> > identifying >> > >> how many of the enclosed activities failed. >> > >> >> > >> > >> >> > >> > >> >> > >> Proposed syntax >> > >> >> > >> ================ >> > >> >> > >> <flow standard-attributes> >> > >> >> > >> standard-elements >> > >> >> > >> <completionCondition/>? >> > >> >> > >> <links>? >> > >> >> > >> <link name="ncname">+ >> > >> >> > >> </links> >> > >> >> > >> activity+ >> > >> >> > >> </flow> >> > >> >> > >> > >> >> > >> <completionCondition> >> > >> >> > >> <conditions branch="xsd:integer"? >> > >> >> > >> expression=xpath?/>? >> > >> >> > >> <ignoreFaults>? >> > >> >> > >> <fault name="qname"? value="ncname"?/>* >> > >> >> > >> <ignoreAll/>? >> > >> >> > >> </ignoreFaults> >> > >> >> > >> </completionCondition> >> > >> >> > >> > >> >> > >> Attribute branch is used to specify a condition of flavor >> > "wait for >> > >> /N/ out of /M/ activities to complete", or more precisely value N. >> > >> Attribute expression is used to specify a Boolean >> > condition operating >> > >> upon process variables or a condition of flavor "the two most >> > >> important requests completed". >> > >> >> > >> > >> >> > >> Both conditions ( branch and expression) may be specified >> > at the same >> > >> time. They will be checked when one instance of the scope activity >> > >> reaches the end. If at least one condition evaluates to true all >> > >> active instances will be terminated. >> > >> >> > >> > >> >> > >> Element <ignoreFaults> specifies faults that may be >> > ignored. Element >> > >> fault is used to specify a fault which may be ignored >> > (fault name and >> > >> fault data may be specified). Element <ignoreAll> would >> > mean that all >> > >> faults thrown/rethrown by any concurrent activity/scope may be >> > >> ignored. If this element is specified <fault> element must >> > be omitted. >> > >> >> > >> > >> >> > >> Completion condition failure >> > >> >> > >> ============================= >> > >> >> > >> A new standard fault, e.g. completionConditionFailure, should be >> > >> introduced to notify that the completion condition of a >> > flow activity >> > >> evaluated to false (note: all concurrent activities have been >> > >> completed). The fault is thrown in the scope enclosing the >> > flow element. >> > >> >> > >> > >> >> > >> Completion condition and links >> > >> >> > >> ============================== >> > >> >> > >> There should be no difference between a flow activity with a >> > >> completion condition and a flow activity without >> > completion condition. >> > >> For example, if the completion condition fails all links >> > leaving the >> > >> flow activity should have value "false" (or be reverted to >> > a negative >> > >> status). >> > >> >> > >> > >> >> > >> There are just a few additional rules: >> > >> >> > >> (1) Let's assume enclosed activity A is the source of a >> > link. If the >> > >> completion condition evaluates to true and activity A is >> > not completed >> > >> it will be terminated and the value of the link will be >> > set to "false". >> > >> >> > >> (2) Let's assume enclosed activity A is the source of a >> > link and the >> > >> activity failed but the fault is "ignored" by the enclosing flow >> > >> activity. The value of the link will be set to "false". >> > >> >> > >> > >> >> > >> New function for completion condition of flavor "the two most >> > >> important requests completed" >> > >> >> > >> >> > ============================================================== >> > ============================== >> > >> >> > >> >> > >> For completion conditions of flavor "the two most >> > important requests >> > >> completed" standard attribute "name" must be specified for all >> > >> enclosing activities in order to be able to distinguish them. In >> > >> addition a new function, e.g. isCompleted('activityName') must be >> > >> introduced. The semantics of the function is: if activity >> > completed >> > >> successfully the function returns value true. >> > >> >> > >> > >> >> > >> Example >> > >> >> > >> <completionCondition expression= >> > >> >> > >> "isCompleted('A') AND isCompleted('B')" > >> >> > >> </completionConditions> >> > >> >> > >> > >> >> > >> > >> >> > >> Regards, >> > >> >> > >> > >> >> > >> Ivana >> > >> >> > >> > >> >> > >> -----Original Message----- >> > >> *From:* Alex Yiu [mailto:alex.yiu@oracle.com] >> > >> *Sent:* Samstag, 11. September 2004 00:49 >> > >> *To:* Axel Martens >> > >> *Cc:* 'edwink@collaxa.com >> > <mailto:edwink@collaxa.com>'; Trickovic, >> > >> Ivana; 'satisht@microsoft.com <mailto:satisht@microsoft.com>'; >> > >> 'wsbpel@lists.oasis-open.org >> > >> <mailto:wsbpel@lists.oasis-open.org>'; Alex Yiu >> > >> *Subject:* Re: [wsbpel] Issue 6 - Rough draft of >> > proposal for vote >> > >> >> > >> >> > >> Hi, Axel, >> > >> >> > >> Thanks for liking parts of my proposal so far. >> > >> Actually, the idea of my proposal is borrowed from a part of >> > >> presentation from Ivana and Dieter Roller in March F2F. I just >> > >> generalize it to apply to <flow> also. >> > >> >> > >> About using links or not: >> > >> I don't have a huge opposition to Axel's proposal >> > which enriches >> > >> the semantics of joinCondition evaluation. However, it >> > is not that >> > >> difficult for people to make mistakes in joinCondition. >> Look at >> > >> the 2-out-of-3 example. The join condition already gets so >> > >> complicated. If people make a mistake in their >> > joinCondition, the >> > >> whole flow can get struck for no good reasons. (The >> > >> completeCondition approach will less likely to have >> > the whole flow >> > >> struck. Because, it does not introduce a new parallel >> > activity in >> > >> the flow). But, if this is what Petri-net-oriented and >> > >> control-link-oriented audience really want, I can >> > accept it in a >> > >> sense, as long as this is not the only way to achieve similar >> > >> business logic. >> > >> >> > >> About static vs dynamic parallelism: >> > >> Static parallelism is basically <flow> construct in >> > BPEL. Dynamic >> > >> parallelism is "parallel forEach" or "bundle". Issue 4 >> > and 147 are >> > >> related issues. >> > >> > >> http://www.choreology.com/external/WS_BPEL_issues_list.html#Issue4 >> > >> > >> http://www.choreology.com/external/WS_BPEL_issues_list.html#Issue147 >> > >> >> > >> About "Terminating still running tasks versus proceeding in >> > >> control flow while those tasks are >> > >> still running": >> > >> I am not 100% that I understand your question. Let me try to >> > >> answer it anyway. The completeCondition is about triggering >> > >> termination of still-running tasks. The "proceeding in control >> > >> flow" (if I understand you correctly) will be handled >> > by an outter >> > >> flow. [I guess it is related to (hotel and (train or >> > plane)) flow??] >> > >> >> > >> About changes of "forcedTermination" fault handler: >> > >> If you got a chance to see some recent emails on Issue >> > 135, Satish >> > >> has recently suggested to remove the notion >> "forcedTermination" >> > >> fault and replace its fault handler with cancelHandler. Frank, >> > >> Yaron, Edwin and I all agree with this direction. Because, >> > >> overloading fault with the concept of "forcedTermination" is a >> > >> "false economy" and it creates quite a bit of >> > unnecessary confusion. >> > >> >> > >> I don't think we should go back to this route or even further >> > >> overload the "forcedTermination" fault handler >> > semantics. Because, >> > >> fault handling is way too generic and the changes you >> mentioned >> > >> will create even more confusion. (e.g. Will this >> > change of marking >> > >> as "completed" apply to all "forcedTermination" fault >> handler / >> > >> cancel handler of all scopes? ) >> > >> >> > >> I guess most of us agree that we should have a new >> mechanism to >> > >> kill / do an early completion of a flow in a nice and >> > clean way. >> > >> However, overloading a standard fault handler does not >> > seem to be >> > >> the best one. I would rather introduce a construct >> > which is very >> > >> specific to <flow> or parallel-forEach. For example, this >> > >> <completeCondition> construct or maybe a new activity called >> > >> <completeFlow />. I will send out more emails on >> > joint thinking >> > >> of both Issue 6 and Issue 135. Please stay tuned. >> > >> >> > >> >> > >> Thanks! >> > >> >> > >> >> > >> >> > >> Regards, >> > >> Alex Yiu >> > >> >> > >> >> > >> Axel Martens wrote: >> > >> >> > >>> >> > >>> Hi, >> > >>> >> > >>> I like the simplicity of the syntax of Alex's >> > proposal. Although, >> > >>> for me it is quite easy to model in terms of links and join >> > >>> conditions, and I want to keep my proposal alive >> > (because of the >> > >>> minimal changes to BPEL's syntax and semantics), it >> > looks like a >> > >>> nice macro to provide more convenience to the customers. >> > >>> >> > >>> Alex, could you shortly explain to me, what do you >> > mean by static >> > >>> and dynamic parallelism? How do you handle the two >> > different cases >> > >>> after evaluating the completeCondition: Terminating >> > still running >> > >>> tasks versus proceeding in control flow while those tasks are >> > >>> still running (Sorry, I missed your previous emails)? >> > >>> >> > >>> I agree to Alex's opinion, that we need a mechanism to kill >> > >>> parallel flow nice and clean. This could be done >> > either by a new >> > >>> mechanism which does not throw a fault or by changing the way >> > >>> fault are handled. I have discussed already an example of the >> > >>> second case with Ivana, and I like to tell you, what I >> have in >> > >>> mind. Look at the following example: >> > >>> >> > >>> <scope name="scopeFlow"> >> > >>> ... >> > >>> <flow> >> > >>> <link name="linkA"/> >> > >>> <link name="linkB"/> >> > >>> >> > >>> <scope name="scopeA"> >> > >>> ... >> > >>> <invoke name="A" ...> >> > >>> <source linkName="linkA" ...> >> > >>> </invoke> >> > >>> </scope> >> > >>> >> > >>> <scope name="scopeB"> >> > >>> ... >> > >>> <invoke name="B" ...> >> > >>> <source linkName="linkB" ...> >> > >>> </invoke> >> > >>> </scope> >> > >>> >> > >>> <throw name="C" faultName="bpws:forcedCompletion" >> > >>> joinCondition="linkA OR linkB" >> > >>> joinEvaluation="immediate"> >> > >>> <target linkName="linkA" ...> >> > >>> <target linkName="linkB" ...> >> > >>> </throw> >> > >>> >> > >>> </flow> >> > >>> </scope> >> > >>> >> > >>> First, I explain the situation: In the example above, >> > activity C >> > >>> will be executed if one of the two activities A and B was >> > >>> successfully completed. Activity C throws the fault >> > >>> "forcedCompletion". Like each other fault, this >> > forces the scope >> > >>> "scopeFlow" to terminate still running activities. >> > Assume, there >> > >>> was a fault handler defined in this scope which >> > catches the fault >> > >>> "forcedCompletion" (omitted in here), the process >> > continues after >> > >>> scope "scopeFlow". A problem arises, if scope >> > "scopeFlow" should >> > >>> be compensated. Because it was exited from a fault >> handler, no >> > >>> compensation handler was installed. >> > >>> >> > >>> Now, I explain my solution: In the example, I have >> > chosen a new >> > >>> "standard" fault name: "forcedCompletion". The only necessary >> > >>> change is to allow a fault handler that catches this fault to >> > >>> install a compensation handler for the same scope, >> > i.e. to mark >> > >>> the scope "scopeFlow" as "completed" instead of "exited". >> > >>> >> > >>> The standard compensation mechanism will only undo those >> > >>> ("scoped") activities within the scope, which >> > actually have been >> > >>> successfully completed, i.e. scopeA or scopeB or may be both. >> > >>> >> > >>> Axel. >> > >>> ---------------------------------------- >> > >>> Axel Martens >> > >>> >> > >>> Post Doc Researcher >> > >>> Component Systems Group >> > >>> IBM TJ Watson Research Center >> > >>> Hawthorne, NY (USA) >> > >>> Phone: (914) 784-7480 >> > >>> E-mail: amarten@us.ibm.com <mailto:amarten@us.ibm.com> >> > >>> >> > >>> >> > >>> *Alex Yiu <alex.yiu@oracle.com> <mailto:alex.yiu@oracle.com>* >> > >>> >> > >>> 09/10/2004 12:10 AM >> > >>> >> > >>> > >>> To >> > >>> Alex Yiu <alex.yiu@oracle.com> >> > <mailto:alex.yiu@oracle.com> >> > >>> cc >> > >>> "Trickovic, Ivana" <ivana.trickovic@sap.com> >> > >>> <mailto:ivana.trickovic@sap.com>, Axel >> > Martens/Watson/IBM@IBMUS, >> > >>> "'edwink@collaxa.com'" <mailto:%27edwink@collaxa.com%27> >> > >>> <edwink@collaxa.com> <mailto:edwink@collaxa.com>, >> > >>> "'satisht@microsoft.com'" >> <mailto:%27satisht@microsoft.com%27> >> > >>> <satisht@microsoft.com> <mailto:satisht@microsoft.com>, >> > >>> "'wsbpel@lists.oasis-open.org'" >> > >>> <mailto:%27wsbpel@lists.oasis-open.org%27> >> > >>> <wsbpel@lists.oasis-open.org> >> > >>> <mailto:wsbpel@lists.oasis-open.org>, Alex Yiu >> > >>> <alex.yiu@oracle.com> <mailto:alex.yiu@oracle.com> >> > >>> Subject >> > >>> Re: [wsbpel] Issue 6 - Rough draft of proposal for vote >> > >>> >> > >>> >> > >>> >> > >>> > >>> >> > >>> >> > >>> >> > >>> >> > >>> >> > >>> >> > >>> Hi, >> > >>> >> > >>> Here are some examples how to use completeCondition to >> express >> > >>> similar business logic in Axel's previous email: >> > >>> >> > >>> (A) "Select one out of three" example: >> > >>> <flow> >> > >>> <completeCondition *branch="1"* /> >> > >>> <invoke name="CheckAirlineA" ... /> >> > >>> <invoke name="CheckAirlineB" ... /> >> > >>> <invoke name="CheckAirlineC" ... /> >> > >>> </flow> >> > >>> >> > >>> >> > >>> (B) "Select two out of three" example: >> > >>> <flow> >> > >>> <completeCondition *branch="2"* /> >> > >>> <invoke name="AskRefereeA" ... /> >> > >>> <invoke name="AskRefereeB" ... /> >> > >>> <invoke name="AskRefereeC" ... /> >> > >>> </flow> >> > >>> >> > >>> As you guys can see, the completeCondition declaration is >> very >> > >>> straight forward and simple. No complicated links and >> > >>> joinCondition usage. >> > >>> >> > >>> (C) "(Plane or Train) and Hotel" example: It would become two >> > >>> flow constructed (nested). >> > >>> >> > >>> >> > >>> <assign> ... <to variable="planeResult"></assign> >> > >>> <!-- initialize "planeResult" with NOT-OK value --> >> > >>> <assign> ... <to variable="trainResult"></assign> >> > >>> <!-- initialize "trainResult" with NOT-OK value --> * >> > >>> <flow name="checkIterinary">* >> > >>> *<flow name="PlaneOrPlane">* >> > >>> <completeCondition> >> > >>> fn:planeOK(planeResult) *or* >> > fn:trainOK(trainResult) >> > >>> </completeCondition> >> > >>> <invoke name="CheckPlane" >> > outputVariable="planeResult" ... /> >> > >>> <invoke name="CheckTrain" >> > outputVariable="trainResult" ... /> >> > >>> *</flow> * >> > >>> <invoke name="checkHotel" /> * >> > >>> </flow> >> > >>> <switch name="bookingSwitch">* >> > >>> <case> >> > >>> <condition> >> > >>> (fn:planeOK(planeResult) *or* fn:trainOK(trainResult)) >> > >>> *and* fn:hotelOK(hotelResult) >> > >>> </condition> >> > >>> <invoke name="invokeBooking" ... /> >> > >>> </case> >> > >>> <otherwise> >> > >>> <invoke name="writeInformation" ... /> >> > >>> </otherwise> * >> > >>> </switch>* >> > >>> >> > >>> >> > >>> Please note that regardless whether we pick a link-oriented >> > >>> approach or completeCondition approach: >> > >>> >> > >>> * The initialization of result variables are >> > needed because >> > >>> of potential cancellation of one of the invoke between >> > >>> train and plane >> > >>> * The "fn:*()" represents the logic to determine >> whether a >> > >>> traveling resource is available. They are used in >> either >> > >>> the transitionCondition of links or the condition of >> > >>> switch/case. >> > >>> >> > >>> As you guys see, we don't need declare to six links. The >> > >>> completeCondition and case-condition are much simpler >> > and easier >> > >>> to understand. >> > >>> >> > >>> I attach a diagram to illustrate the above flows. >> > >>> >> > >>> I guess we can still more time in terms of refiniment of >> > >>> joinCondition evaluation. However, I don't think that >> > should be >> > >>> the only approach to achieve complete condition related >> logic. >> > >>> >> > >>> >> > >>> Thanks!!! >> > >>> >> > >>> Regards, >> > >>> Alex Yiu >> > >>> >> > >>> >> > >>> >> > >>> >> > >>> Alex Yiu wrote: >> > >>> >> > >>> Hi, >> > >>> >> > >>> +1 to what Ivana said in general. >> > >>> >> > >>> Few points to add: >> > >>> >> > >>> * Axel's proposed enhancement to control links evaluation >> > >>> works to an extent for static parallelism > (e.g. >> <flow>). >> > >>> However, control links do not work well in dynamic >> > >>> parallelism (e.g. "parallel forEach" or >> > "bundle"). I think >> > >>> the notion of completeCondition (borrowed from Ivana >> and >> > >>> DK) is general enough and it should be applied to both >> > >>> static and dynamic parallelism. A general >> > completeCondition >> > >>> mechanism will be easier for BPEL users to learn. >> > >>> * Even in a pure static parallelism case, >> > completeCondition >> > >>> has much better code clarity. It is more declarative >> and >> > >>> easier for BPEL users to understand. It will eliminate >> > >>> significant amount of joinCondition >> > programming, which may >> > >>> be error prone. (I will send another email later to >> show >> > >>> how completeCondition can be used to express the same >> > >>> semantics of Axel's example). >> > >>> * In one of my previous emails, I also tried to >> > use a "macro" >> > >>> way to illustrate how outstanding running flows can be >> > >>> cancelled by throwing a fault within a scope. The >> > >>> illustration has the same compensation handler >> > installation >> > >>> problem that Ivana has pointed out. The "illustraction >> > >>> macro" does NOT carry a desirable and intended >> > semantics. >> > >>> We need to create / describe a new mechanism to cancel >> > >>> parallel flow without throwing a fault. (That >> > was discussed >> > >>> briefly between Edwin and me at Oracle). >> > >>> >> > >>> >> > >>> Thanks! >> > >>> >> > >>> >> > >>> Regards, >> > >>> Alex Yiu >> > >>> >> > >>> >> > >>> >> > >>> Trickovic, Ivana wrote: >> > >>> Axel, >> > >>> > >>> I find the idea interesting. In fact, I was >> discussing the >> > >>> completion condition issue with Dieter Koenig during >> > the last f2f >> > >>> meeting and his suggestion was also to try to resolve >> > this issue >> > >>> using links. And we identified that several changes need >> to be >> > >>> done, including removing restriction for >> > jonCondition, that "the >> > >>> join condition is evaluated as soon as all incoming >> > links of the >> > >>> activity are determined" - so definitely "immediate" >> semantics >> > >>> needs to be introduced. >> > >>> > >>> I have the following comments on your proposal. >> > >>> 1. In your proposal you are using a fault >> > >>> (bpws:forcedTermination) to terminate all active parallel >> > >>> branches. But this changes the outcome of the flow >> > activity. It >> > >>> will always end abnormally and compensation handler (if it is >> > >>> defined) will never be installed. Although completion >> > condition >> > >>> has evaluated to true and needed activities have completed >> the >> > >>> enclosing flow activity will end abnormally. Is this really >> > >>> intended semantics? >> > >>> > >>> 2. Your proposal does not address some pain >> points. >> > For example, >> > >>> in case of "N out of M", N<M there many possible >> "variations": >> > >>> (A) One enclosed activity may experience problems but >> > the <flow> >> > >>> activity may succeed >> > >>> (B) One of enclosed activities may experience a severe error, >> > >>> which may have impact on the <flow> activity >> > >>> The question is what to do with running activities? >> > In the latter >> > >>> case, reasonable behavior would be: if one enclosed >> > activity does >> > >>> not succeed other running activities should be >> > cancelled and the >> > >>> flow activity should try to recover. In the former case, we >> > >>> should allow active parallel activities to complete >> > their work. >> > >>> This is not supported in your proposal. >> > >>> > >>> Regards, >> > >>> > >>> >> > >>> Ivana >> > >>> >> > >> [stuff deleted] >> > >> >> > > >> > >> > To unsubscribe from this mailing list (and be removed from >> > the roster of the OASIS TC), go to >> > http://www.oasis-open.org/apps/org/workgroup/wsbpel/members/le >> > ave_workgroup.php. >> > >> >> To unsubscribe from this mailing list (and be removed from the roster >> of the OASIS TC), go to >> http://www.oasis-open.org/apps/org/workgroup/wsbpel/members/leave_workgroup.php. >> >> > > To unsubscribe from this mailing list (and be removed from the roster > of the OASIS TC), go to > http://www.oasis-open.org/apps/org/workgroup/wsbpel/members/leave_workgroup.php. > > >
[Date Prev] | [Thread Prev] | [Thread Next] | [Date Next] -- [Date Index] | [Thread Index] | [List Home]