Thank you for the suggestions for using a different monitor (other than SOAPMonitor) ... I tried using tcpmon instead and I now see the SOAP fault in the response.
Please note: This bug is already logged at http://nagoya.apache.org/jira/browse/AXIS-1551 Greg Michalopoulos wrote: > > If you do not get SOAP response, then how does your client know the fault > has occurred? Are you using tcpmon? > > -----Original Message----- > From: Keast Ann [mailto:[EMAIL PROTECTED] > Sent: Wednesday, September 22, 2004 1:32 PM > To: [EMAIL PROTECTED] > Subject: Re: Axis 1.1 samples.fault: No SOAP Fault response > > I tried the modified samples fault code (in the samples.fault package) from > Richard Hanson at > http://www.mail-archive.com/[EMAIL PROTECTED]/msg03552.html. > This code includes a case where an AxisFault is thrown when the > getEmployees() operation is called. I made no modifications to the source, > deployed the webservice with the AdminClient, and invoked it from the > EmployeeClient. > > Again, when I request a valid employee "#001" - I get a SOAP response for > Bill Gates. (Viewable in SOAPMonitor) > > When I call the getEmployees operation - I do not get a SOAP Response. > The AxisFault is NOT returned in the form of SOAP. > > In my EmployeeClient I/O, I get: > =========================================================== > Get Employees - > Fault ===================================================== > AxisFault > faultCode: {http://schemas.xmlsoap.org/soap/envelope/}Server.Client > faultSubcode: > faultString: Operation is not yet implemented. > faultActor: > faultNode: > faultDetail: > {}string:getEmployees() > {}string:Not Implemented > =========================================================== > > So am AxisFault is thrown and caught(as expected in the code), but it isn't > sent back as SOAP. > > public Employee[] getEmployees() throws AxisFault { > AxisFault fault = new AxisFault(); > fault.setFaultCode(new > QName("http://schemas.xmlsoap.org/soap/envelope/", "Server.Client")); > fault.setFaultString("Operation is not yet implemented."); > fault.addFaultDetailString("getEmployees()"); > fault.addFaultDetailString("Not Implemented"); > throw fault; > } > > I don't understand ... very very confused. Since the AXIS API states "An > exception which maps cleanly to a SOAP fault. This is a base class for > exceptions which are mapped to faults." > > Are there any configuration options that I need to turn on in Axis? > Perhaps in the server-config.wsdd? > > Thank you, > Ann > > [EMAIL PROTECTED] wrote: > > > > from memory the nosuchemployee extends remote exception (as opposed to > > extending axis fault) hence you see an exception client side. the > > recommended way is to use faults as opposed to exceptions for interop. > > the fault sample included in axis1.1 isnt especially good in my > > opinion - > > > > Richard Hanson posted some useful notes at > > http://www.mail-archive.com/[EMAIL PROTECTED]/msg03552.html > > > > also look at > > http://www-106.ibm.com/developerworks/xml/library/ws-tip-jaxrpc.html > > > > /t > > > > > I tried the samples.fault web service included in Axis 1.1 Release. > > > I made no modifications to the source, deployed the webservice with > > > the AdminClient, and invoked it from the EmployeeClient. > > > > > > When I request a valid employee "#001" - I get a SOAP response for > > > Bill Gates. When I request an invalid employee "1" - I do not get a > > > SOAP Response. I get the stack dump in the EmployeeClient I/O window > > > (see below). > > > > > > I have no idea why the NoSuchEmployee exception is NOT returned in > > > the form of a SOAP Fault. I am using SOAP Monitor to view the > > > request/responses. > > > > > > Could you please tell me what I am doing wrong or if I am taking the > > > wrong approach? This is my first experimentation with SOAP Faults. I > > > am using Axis Final Version 1.1 > > > > > > Thank you, > > > Ann > > > > > > Stack Dump: > > > samples.faults.NoSuchEmployeeFault > > > at > > > sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native > > > Method) > > > at > > > > sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAcces > sorImpl.java:39) > > > at > > > > sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstruc > torAccessorImpl.java:27) > > > at > > > java.lang.reflect.Constructor.newInstance(Constructor.java:274) > > > at java.lang.Class.newInstance0(Class.java:308) > > > at java.lang.Class.newInstance(Class.java:261) > > > at > > > > org.apache.axis.encoding.ser.BeanDeserializer.<init>(BeanDeserializer.java:1 > 25) > > > at > > > > org.apache.axis.encoding.ser.BeanDeserializerFactory.getGeneralPurpose(BeanD > eserializerFactory.java:127) > > > at > > > > org.apache.axis.encoding.ser.BaseDeserializerFactory.getDeserializerAs(BaseD > eserializerFactory.java:125) > > > at > > > > org.apache.axis.encoding.DeserializationContextImpl.getDeserializer(Deserial > izationContextImpl.java:481) > > > at > > > > org.apache.axis.encoding.DeserializationContextImpl.getDeserializerForType(D > eserializationContextImpl.java:554) > > > at > > > > org.apache.axis.message.SOAPFaultDetailsBuilder.onStartChild(SOAPFaultDetail > sBuilder.java:177) > > > at > > > > org.apache.axis.encoding.DeserializationContextImpl.startElement(Deserializa > tionContextImpl.java:1040) > > > at > > > org.apache.xerces.parsers.AbstractSAXParser.startElement(Unknown Source) > > > at > > > org.apache.xerces.impl.XMLNSDocumentScannerImpl.scanStartElement(Unk > > > nown > > > Source) > > > at > > > org.apache.xerces.impl.XMLDocumentFragmentScannerImpl$FragmentConten > > > tDispatcher.dispatch(Unknown > > > Source) > > > at > > > org.apache.xerces.impl.XMLDocumentFragmentScannerImpl.scanDocument(U > > > nknown > > > Source) > > > at > > > org.apache.xerces.parsers.XML11Configuration.parse(Unknown > > > Source) > > > at org.apache.xerces.parsers.DTDConfiguration.parse(Unknown > > > Source) > > > at org.apache.xerces.parsers.XMLParser.parse(Unknown Source) > > > at org.apache.xerces.parsers.AbstractSAXParser.parse(Unknown > > > Source) > > > at javax.xml.parsers.SAXParser.parse(SAXParser.java:345) > > > at > > > > org.apache.axis.encoding.DeserializationContextImpl.parse(DeserializationCon > textImpl.java:257) > > > at org.apache.axis.SOAPPart.getAsSOAPEnvelope(SOAPPart.java:582) > > > at org.apache.axis.Message.getSOAPEnvelope(Message.java:447) > > > at org.apache.axis.client.Call.invokeEngine(Call.java:2702) > > > at org.apache.axis.client.Call.invoke(Call.java:2665) > > > at org.apache.axis.client.Call.invoke(Call.java:2355) > > > at org.apache.axis.client.Call.invoke(Call.java:2278) > > > at org.apache.axis.client.Call.invoke(Call.java:1772) > > > at > > > samples.faults.EmployeeClient.main(EmployeeClient.java:48) > > > Exception in thread "main" > > >