Return-Path: X-Original-To: apmail-cxf-issues-archive@www.apache.org Delivered-To: apmail-cxf-issues-archive@www.apache.org Received: from mail.apache.org (hermes.apache.org [140.211.11.3]) by minotaur.apache.org (Postfix) with SMTP id 59083118D4 for ; Tue, 8 Apr 2014 19:50:26 +0000 (UTC) Received: (qmail 91738 invoked by uid 500); 8 Apr 2014 19:50:25 -0000 Delivered-To: apmail-cxf-issues-archive@cxf.apache.org Received: (qmail 91151 invoked by uid 500); 8 Apr 2014 19:50:22 -0000 Mailing-List: contact issues-help@cxf.apache.org; run by ezmlm Precedence: bulk List-Help: List-Unsubscribe: List-Post: List-Id: Reply-To: dev@cxf.apache.org Delivered-To: mailing list issues@cxf.apache.org Received: (qmail 89868 invoked by uid 99); 8 Apr 2014 19:50:18 -0000 Received: from arcas.apache.org (HELO arcas.apache.org) (140.211.11.28) by apache.org (qpsmtpd/0.29) with ESMTP; Tue, 08 Apr 2014 19:50:18 +0000 Date: Tue, 8 Apr 2014 19:50:18 +0000 (UTC) From: "David J. M. Karlsen (JIRA)" To: issues@cxf.apache.org Message-ID: In-Reply-To: References: Subject: [jira] [Commented] (CXF-5675) java.lang.ClassCastException: java.net.URI cannot be cast to java.lang.String when adding Location to Response MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: quoted-printable X-JIRA-FingerPrint: 30527f35849b9dde25b450d4833f0394 [ https://issues.apache.org/jira/browse/CXF-5675?page=3Dcom.atlassian.j= ira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=3D139633= 48#comment-13963348 ]=20 David J. M. Karlsen commented on CXF-5675: ------------------------------------------ {noformat} javax.ws.rs.ProcessingException: java.lang.ClassCastException: java.net.URI= cannot be cast to java.lang.String =09at org.apache.cxf.jaxrs.client.WebClient.handleResponse(WebClient.java:1= 174) =09at org.apache.cxf.jaxrs.client.WebClient.doResponse(WebClient.java:1138) =09at org.apache.cxf.jaxrs.client.WebClient.doChainedInvocation(WebClient.j= ava:1075) =09at org.apache.cxf.jaxrs.client.WebClient.doInvoke(WebClient.java:869) =09at org.apache.cxf.jaxrs.client.WebClient.doInvoke(WebClient.java:840) =09at org.apache.cxf.jaxrs.client.WebClient.invoke(WebClient.java:307) =09at org.apache.cxf.jaxrs.client.WebClient.post(WebClient.java:316) =09at com.davidkarlsen.traxidx.srv.service.blob.BlobServiceTest.postFile(Bl= obServiceTest.java:61) =09at com.davidkarlsen.traxidx.srv.service.blob.BlobServiceTest.assertIniti= alAddBlobIs201(BlobServiceTest.java:39) =09at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) =09at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.= java:62) =09at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAcces= sorImpl.java:43) =09at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(Framework= Method.java:47) =09at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCal= lable.java:12) =09at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMe= thod.java:44) =09at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMet= hod.java:17) =09at org.springframework.test.context.junit4.statements.RunBeforeTestMetho= dCallbacks.evaluate(RunBeforeTestMethodCallbacks.java:74) =09at org.springframework.test.context.junit4.statements.RunAfterTestMethod= Callbacks.evaluate(RunAfterTestMethodCallbacks.java:83) =09at org.springframework.test.context.junit4.statements.SpringRepeat.evalu= ate(SpringRepeat.java:72) =09at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runCh= ild(SpringJUnit4ClassRunner.java:232) =09at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runCh= ild(SpringJUnit4ClassRunner.java:89) =09at org.junit.runners.ParentRunner$3.run(ParentRunner.java:238) =09at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:63) =09at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:236) =09at org.junit.runners.ParentRunner.access$000(ParentRunner.java:53) =09at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:229) =09at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.= java:26) =09at org.springframework.test.context.junit4.statements.RunBeforeTestClass= Callbacks.evaluate(RunBeforeTestClassCallbacks.java:61) =09at org.junit.internal.runners.statements.RunAfters.evaluate(RunAfters.ja= va:27) =09at org.springframework.test.context.junit4.statements.RunAfterTestClassC= allbacks.evaluate(RunAfterTestClassCallbacks.java:71) =09at org.junit.runners.ParentRunner.run(ParentRunner.java:309) =09at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.run(S= pringJUnit4ClassRunner.java:175) =09at org.junit.runner.JUnitCore.run(JUnitCore.java:160) =09at com.intellij.rt.execution.junit.JUnitStarter.main(JUnitStarter.java:6= 7) Caused by: java.lang.ClassCastException: java.net.URI cannot be cast to jav= a.lang.String =09at org.apache.cxf.jaxrs.client.AbstractClient.setResponseBuilder(Abstrac= tClient.java:389) =09at org.apache.cxf.jaxrs.client.WebClient.handleResponse(WebClient.java:1= 151) =09... 36 more {noformat} I should add that I=C2=B4m runnning localtransport > java.lang.ClassCastException: java.net.URI cannot be cast to java.lang.St= ring when adding Location to Response > -------------------------------------------------------------------------= ------------------------------------- > > Key: CXF-5675 > URL: https://issues.apache.org/jira/browse/CXF-5675 > Project: CXF > Issue Type: Bug > Components: JAX-RS > Affects Versions: 3.0.0-milestone2 > Reporter: David J. M. Karlsen > > Exception: > java.lang.ClassCastException: java.net.URI cannot be cast to java.lang.St= ring > Test: > {code} > Response response =3D getWebClient() > .path("/blob") > .type(MediaType.MULTIPART_FORM_DATA) > .post(multipartBody); > {code} > serverside resource: > {code} > URI blobId =3D UriBuilder.fromResource(getClass()).build(gridFSDB= File.getId()); > return Response.created(blobId).build(); > {code} > because inside WebClient handleResponse -> AbstractClient the values are = assumed to be string arrays, but is an URI object: > {code} > boolean splitHeaders =3D=20 > MessageUtils.isTrue(outMessage.getContextualProperty(HEADER_S= PLIT_PROPERTY)); > for (Map.Entry> entry : protocolHeaders.entr= ySet()) { > if (null =3D=3D entry.getKey()) { > continue; > } > if (entry.getValue().size() > 0) { > if (HttpUtils.isDateRelatedHeader(entry.getKey())) { > currentResponseBuilder.header(entry.getKey(), entry.g= etValue().get(0)); > continue; =20 > } > for (String val : entry.getValue()) { > if (splitHeaders) { > String[] values; > if (val =3D=3D null || val.length() =3D=3D 0) { > {code} -- This message was sent by Atlassian JIRA (v6.2#6252)