Sola-ris created CXF-9114: ----------------------------- Summary: ClientRequestContext#getConfiguration always return null in the MicroProfile RestClient Key: CXF-9114 URL: https://issues.apache.org/jira/browse/CXF-9114 Project: CXF Issue Type: Bug Components: JAX-RS, MicroProfile Affects Versions: 4.1.0 Reporter: Sola-ris
Calling ClientRequestContext#getConfiguration inside of a Filter when using the MicroProfile RestClient always return null, making it impossible to access properties set on the RestClientBuilder inside ClientRequest/ResponseFilters. *To reproduce:* {code:java} @Path("") public interface GreetingClient { @GET Response greet(); } public static class Filter implements ClientRequestFilter { @Override public void filter(ClientRequestContext requestContext) { System.out.println(requestContext.getConfiguration().getProperty("foo")); } } RestClientBuilder.newBuilder() .baseUri(URI.create("http://localhost:8080")) .property("foo", "bar") .register(Filter.class) .build(GreetingClient.class) .greet(); {code} *Stacktrace:* {noformat} jakarta.ws.rs.ProcessingException: java.lang.NullPointerException: Cannot invoke "jakarta.ws.rs.core.Configuration.getProperty(String)" because the return value of "jakarta.ws.rs.client.ClientRequestContext.getConfiguration()" is null at org.apache.cxf.jaxrs.client.AbstractClient.checkClientException(AbstractClient.java:645) at org.apache.cxf.jaxrs.client.AbstractClient.preProcessResult(AbstractClient.java:619) at org.apache.cxf.jaxrs.client.ClientProxyImpl.doChainedInvocation(ClientProxyImpl.java:926) at org.apache.cxf.jaxrs.client.ClientProxyImpl.invoke(ClientProxyImpl.java:347) at org.apache.cxf.microprofile.client.proxy.MicroProfileClientProxyImpl.invokeActual(MicroProfileClientProxyImpl.java:496) at org.apache.cxf.microprofile.client.proxy.MicroProfileClientProxyImpl$Invoker.call(MicroProfileClientProxyImpl.java:515) at org.apache.cxf.microprofile.client.cdi.CDIInterceptorWrapper$BasicCDIInterceptorWrapper.invoke(CDIInterceptorWrapper.java:43) at org.apache.cxf.microprofile.client.proxy.MicroProfileClientProxyImpl.invoke(MicroProfileClientProxyImpl.java:492) at jdk.proxy2/jdk.proxy2.$Proxy21.greet(Unknown Source) at org.example.MpRestClientConfigurationReproducerTest.testAccessConfigurationInFilter(MpRestClientConfigurationReproducerTest.java:24) at java.base/java.lang.reflect.Method.invoke(Method.java:580) at java.base/java.util.ArrayList.forEach(ArrayList.java:1596) at java.base/java.util.ArrayList.forEach(ArrayList.java:1596) Caused by: java.lang.NullPointerException: Cannot invoke "jakarta.ws.rs.core.Configuration.getProperty(String)" because the return value of "jakarta.ws.rs.client.ClientRequestContext.getConfiguration()" is null at org.example.MpRestClientConfigurationReproducerTest$Filter.filter(MpRestClientConfigurationReproducerTest.java:38) at org.apache.cxf.jaxrs.client.spec.ClientRequestFilterInterceptor.handleMessage(ClientRequestFilterInterceptor.java:70) at org.apache.cxf.phase.PhaseInterceptorChain.doIntercept(PhaseInterceptorChain.java:307) at org.apache.cxf.jaxrs.client.AbstractClient.doRunInterceptorChain(AbstractClient.java:717) at org.apache.cxf.microprofile.client.proxy.MicroProfileClientProxyImpl.doRunInterceptorChain(MicroProfileClientProxyImpl.java:184) at org.apache.cxf.jaxrs.client.ClientProxyImpl.doChainedInvocation(ClientProxyImpl.java:924) ... 10 more {noformat} [Executable reprodcucer|https://github.com/Sola-ris/cxf-reproducers] -- This message was sent by Atlassian Jira (v8.20.10#820010)