Elements of subtypes returned in wrong order in webservice response -------------------------------------------------------------------
Key: AXIS2-4093 URL: https://issues.apache.org/jira/browse/AXIS2-4093 Project: Axis 2.0 (Axis2) Issue Type: Bug Components: adb Affects Versions: 1.3 Reporter: Balaji Hari Priority: Critical When axis service returns elements of subtypes it returns in reverse order, 1. subclass 2. super class. Snippet from WSDL definition: - <xs:complexType name="RuleDTO"> - <xs:sequence> <xs:element minOccurs="0" name="annotation" nillable="true" type="xs:string" /> <xs:element maxOccurs="unbounded" minOccurs="0" name="applicableTrails" nillable="true" type="xs:int" /> <xs:element minOccurs="0" name="deviceTypeId" nillable="true" type="xs:int" /> ... <xs:element minOccurs="0" name="subject" nillable="true" type="ax21:SubjectDTO" /> </xs:sequence> </xs:complexType> Definition of SubjectDTO (which has following sub types). <xs:complexType name="SubjectDTO"> - <xs:sequence> <xs:element minOccurs="0" name="caseSensitive" type="xs:boolean" /> <xs:element minOccurs="0" name="frequency" nillable="true" type="xs:int" /> <xs:element minOccurs="0" name="ignoreWhitespace" type="xs:boolean" /> <xs:element minOccurs="0" name="key" nillable="true" type="ax21:KeyDTO" /> <xs:element minOccurs="0" name="COMPONENT_CLASSNAME" nillable="true" type="xs:string" /> </xs:sequence> </xs:complexType> - <xs:complexType name="SubjectCollectionDTO"> - <xs:complexContent> - <xs:extension base="ax21:SubjectDTO"> - <xs:sequence> <xs:element maxOccurs="unbounded" minOccurs="0" name="collection" nillable="true" type="xs:string" /> <xs:element minOccurs="0" name="contiguous" type="xs:boolean" /> <xs:element minOccurs="0" name="ordered" type="xs:boolean" /> </xs:sequence> </xs:extension> </xs:complexContent> </xs:complexType> - <xs:complexType name="SubjectLinesDTO"> - <xs:complexContent> - <xs:extension base="ax21:SubjectCollectionDTO"> <xs:sequence /> </xs:extension> </xs:complexContent> </xs:complexType> Server Response : <return type="com.bmc.bcan.dto.RuleDTO"> <ns1:annotation></ns1:annotation> <ns1:applicableTrails xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:nil="true" /> <ns1:deviceTypeId>0</ns1:deviceTypeId> <!-- SubType Element --> <ns1:subject type="com.bmc.bcan.dto.SubjectLinesDTO"> <ns1:collection>set mls flow full</ns1:collection> <ns1:collection> set mls nde ${global.netflowDestination} ${global.netflowPort} </ns1:collection> <ns1:collection> set mls nde version 5 </ns1:collection> <ns1:collection>set mls nde enable</ns1:collection> <ns1:collection> set mls agingtime long 64 </ns1:collection> <ns1:collection> set mls agingtime fast 16 0 </ns1:collection> <ns1:contiguous>false</ns1:contiguous> <ns1:ordered>false</ns1:ordered> <ns1:caseSensitive>false</ns1:caseSensitive> <ns1:frequency>2</ns1:frequency> <ns1:ignoreWhitespace>true</ns1:ignoreWhitespace> <ns1:key type="com.bmc.bcan.dto.KeyDTO"> <ns1:keyString>458169663-121</ns1:keyString> </ns1:key> </ns1:subject> <ns1:substitutionValidation> true </ns1:substitutionValidation> <ns1:trigger xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:nil="true" /> <ns1:violationSeverity>5</ns1:violationSeverity> </return> For SubjectLinesDTO the subelement collection from SubjectCollectionDTO is returned first instead of elements from SubjectDTO (<ns1:caseSensitive>false</ns1:caseSensitive> <ns1:frequency>2</ns1:frequency> <ns1:ignoreWhitespace>true</ns1:ignoreWhitespace> <ns1:key type="com.bmc.bcan.dto.KeyDTO"> <ns1:keyString>458169663-121</ns1:keyString> </ns1:key>) SubjectLinesDTO.Factory.parse in the client generated stub tries to parse the elements in SubjectDTO first and then SubjectLinesDTO This issue is second part of https://issues.apache.org/jira/browse/AXIS2-4092 which happens when type="fully qualified class name" is changed to xsi:type="ns:SchemaType" (test run) We need a fix for this as this has been a blocker. Balaji -- This message is automatically generated by JIRA. - You can reply to this email to add a comment to the issue online. --------------------------------------------------------------------- To unsubscribe, e-mail: [EMAIL PROTECTED] For additional commands, e-mail: [EMAIL PROTECTED]