OASIS Mailing List ArchivesView the OASIS mailing list archive below
or browse/search using MarkMail.

 


Help: OASIS Mailing Lists Help | MarkMail Help

wsbpel message

[Date Prev] | [Thread Prev] | [Thread Next] | [Date Next] -- [Date Index] | [Thread Index] | [List Home]


Subject: Re: [wsbpel] Issue - 280 - proposal draft for discussion



Hi Mark,

You said "I can see how the keepSrcElement validation could be 
interpreted as being in the same spirit as the message variable type 
compatibility checks". You are very right about that point. The nature 
of disallowing copying "Address" element into a variable of "Employee" 
is very similar to that of disallowing copying "AddressMsgType" data 
into a variable of "EmployeeMsgType".

And, these two kinds of checking do not qualify as real schema 
validation. It is just a very basic sanity check to catch a very bad 
problem earlier before the problem blows up in a larger scale. When 
copying the Employee data into a variable of "Employee", if the required 
employee's FirstName attribute is missing, there will be no fault 
triggered. Hence, it does not qualify as schema validation. If validate 
is turned on, then there will be an fault triggered.

BPEL 1.1 assumes all data copy operations will always produce schema 
valid result. That assumption is infeasible to be implemented (i.e. 
compile time cannot enforce it comprehensively; runtime is too 
expensive). And, that also just violates the requirment of a business 
process to incrementally build up a business document. Hence, Issue 169 
was passed to change that assumption.

When we were drafting Issue 157 proposal, type compatibility of copy 
operation for message type was suggested. And, actually, Yaron was not 
that happy about that also. The argument was very similar to the 
argument on this SG topic. Yaron basically suggested, if one wanted to 
make sure the data is valid, use <validate> activity. But, again my 
argument on this topic is: <validate> is a full blown validation and it 
is too costly to use to make sure that this super basic aspect of copy 
operation is right.

>why we don't enforce any other type compatibility during assigns?
>
During Issue 157, I was thinking to do some validation for simple type 
data. So that, an runtime error can be signaled, if one attempt to 
assign a string value "ABC" to an integer variable.

This design direction was borrowed again from XPath 2.0. It has two 
different operators: "cast as" and "treat as". The former is for simple 
type. The latter is for complex type. If there is something wrong in 
data values, the former will signal a runtime error, while the latter 
would not. This is yet another pragmatic design pattern in a standard 
specification to weigh in the cost and benefit.

Similarly, Yaron had some push back on this design. And, after 
consideration, if the error is detected by <assign><copy> layer as 
mismatchedAssignmentFault, then the underlying XML data model 
implemention behind those BPEL variable will signal that error. If XML 
certain data model implementation is used, the BPEL implementation will 
be no choice but to propagate that error. That error may be covered by 
"subLanguageExecutionFault" or other standard fault and details on when 
the error would occur can be considered outside the scope of BPEL spec. 
Hence, I did not pursue further.


Hope this explains the rationale well.


Thanks!



Regards,
Alex Yiu



Mark Ford wrote:

>I don't like the idea of mandatory schema validation for the keepSrcElement case. I don't recall any other part of the spec where we require validation unless it is explicitly indicated with the <assign>'s validate attribute or the <validate> activity. Section 8.4.3 describes type compatibility but only with respect to assigning to and from message variables. I can see how the
>keepSrcElement validation could be interpreted as being in the same spirit as the message variable type compatibility checks but if that's the case then would people wonder why we don't enforce any other type compatibility during assigns? 
>  
>



Mark Ford wrote:

>I don't like the idea of mandatory schema validation for the keepSrcElement
>case. I don't recall any other part of the spec where we require validation
>unless it is explicitly indicated with the <assign>'s validate attribute or
>the <validate> activity. Section 8.4.3 describes type compatibility but only
>with respect to assigning to and from message variables. I can see how the
>keepSrcElement validation could be interpreted as being in the same spirit
>as the message variable type compatibility checks but if that's the case
>then would people wonder why we don't enforce any other type compatibility
>during assigns? 
>
>The proposed changes to the fault matching rules in Section 12.5 look good.
>My previous concerns regarding the determination of the fault data type have
>been addressed. 
>
>One thing I found missing was that the matching priority only considers the
>order of the <catch> elements when there are multiple compatible matches. I
>was expecting to see some consideration of the SG hierarchy.
>
>For example:
>
>Given the following SG hierarchy:
>
>E1
>|--E2
>   |--E3
>      |--E4
>
>...and the following fault handlers:
>
><faultHandlers>
>   <catch faultElement="E1"> ... </catch>
>   <catch faultElement="E2"> ... </catch>
></faultHandlers>
>
>If the runtime data is E4 then E1 and E2 are both compatible but E1 would be
>selected since it appears first. I would have thought that E2 would have
>been selected since it is closer in the SG hierarchy to E4.
>
>-----Original Message-----
>From: Alex Yiu [mailto:alex.yiu@oracle.com] 
>Sent: Wednesday, July 26, 2006 3:40 AM
>To: wsbpeltc
>Cc: Alex Yiu; 'Dieter Koenig1'; Thomas Schulze
>Subject: [wsbpel] Issue - 280 - proposal draft for discussion
>
>
>Hi all,
>
>Last week, Dieter, Thomas and I have worked together to provide a new 
>proposal draft for Issue 280.
>
>Please take a look!
>(Since this draft is sent out to the public less than 12 hrs before the 
>conf call, I guess voting will be up for in the conf call next week)
>
>
>Thanks!
>
>
>Regards,
>Alex Yiu
>
>
>
>  
>



[Date Prev] | [Thread Prev] | [Thread Next] | [Date Next] -- [Date Index] | [Thread Index] | [List Home]