[ https://issues.apache.org/jira/browse/CXF-5045?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=13762935#comment-13762935 ]
Jim Ma commented on CXF-5045: ----------------------------- Also includes these changes: http://svn.apache.org/viewvc?view=revision&revision=r1487389, http://svn.apache.org/viewvc?view=revision&revision=r1487391,http://svn.apache.org/viewvc?view=revision&revision=r1487404, http://svn.apache.org/viewvc?view=revision&revision=r1487409 > UndeclaredThrowableException thrown in the client side when server responses > with wsa:OnlyNonAnonymousAddressSupported soap12 version fault message > --------------------------------------------------------------------------------------------------------------------------------------------------- > > Key: CXF-5045 > URL: https://issues.apache.org/jira/browse/CXF-5045 > Project: CXF > Issue Type: Bug > Components: WS-* Components > Affects Versions: 2.5.10, 2.6.8, 2.7.5 > Reporter: Jim Ma > Assignee: Jim Ma > Fix For: 2.5.11, 2.6.9, 2.7.6, 3.0.0 > > > As per the wsa spec, the wsa:OnlyNonAnonymousAddressSupported should be > placed in the subCode section, not in the faultCode. The correct soap fault > code should be soap12:sender. SAAJ impl checks if the faultCode is the > standard one. It throws the following exception when meets the unexpected > soapfault code wsa:OnlyNonAnonymousAddressSupported: > java.lang.reflect.UndeclaredThrowableException > at com.sun.proxy.$Proxy48.addNumbers(Unknown Source) > at > org.apache.cxf.systest.ws.addr_feature.WSASoap12ClientServerTest.testNonAnonWSA(WSASoap12ClientServerTest.java:50) > at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) > at > sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) > at > sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) > at java.lang.reflect.Method.invoke(Method.java:601) > at > org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:47) > at > org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12) > at > org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:44) > at > org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17) > at > org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:26) > at > org.junit.internal.runners.statements.RunAfters.evaluate(RunAfters.java:27) > at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:271) > at > org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:70) > at > org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:50) > at org.junit.runners.ParentRunner$3.run(ParentRunner.java:238) > at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:63) > at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:236) > at org.junit.runners.ParentRunner.access$000(ParentRunner.java:53) > at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:229) > at > org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:26) > at > org.junit.internal.runners.statements.RunAfters.evaluate(RunAfters.java:27) > at org.junit.runners.ParentRunner.run(ParentRunner.java:309) > at > org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:50) > at > org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38) > at > org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:467) > at > org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:683) > at > org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:390) > at > org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:197) > Caused by: com.sun.xml.internal.messaging.saaj.SOAPExceptionImpl: > {http://www.w3.org/2005/08/addressing}OnlyNonAnonymousAddressSupported is not > a standard Code value > at > com.sun.xml.internal.messaging.saaj.soap.ver1_2.Fault1_2Impl.checkIfStandardFaultCode(Fault1_2Impl.java:131) > at > com.sun.xml.internal.messaging.saaj.soap.impl.FaultImpl.setFaultCode(FaultImpl.java:124) > at > com.sun.xml.internal.messaging.saaj.soap.impl.FaultImpl.setFaultCode(FaultImpl.java:87) > at > org.apache.cxf.binding.soap.saaj.SAAJUtils.setFaultCode(SAAJUtils.java:65) > at > org.apache.cxf.jaxws.JaxWsClientProxy.createSoapFault(JaxWsClientProxy.java:219) > at > org.apache.cxf.jaxws.JaxWsClientProxy.invoke(JaxWsClientProxy.java:154) > ... 29 more > Inbound Message -- This message is automatically generated by JIRA. If you think it was sent incorrectly, please contact your JIRA administrators For more information on JIRA, see: http://www.atlassian.com/software/jira