Andy McCright created CXF-7644:
----------------------------------

             Summary: TCK/CTS: JAX-RS async client requests should invoke 
interceptor chain on separate thread
                 Key: CXF-7644
                 URL: https://issues.apache.org/jira/browse/CXF-7644
             Project: CXF
          Issue Type: Bug
          Components: JAX-RS
    Affects Versions: 3.2.2
            Reporter: Andy McCright


The JAX-RS 2.1 TCK is using ClientRequestFilters to verify that it is on a 
separate thread than the main client thread.  Although it is not specific in 
the spec that providers like filters must be invoked on a new thread, I believe 
this line from the spec (section 8.4) is what they base this test on:
_Note that in this example, the call to get after calling async returns 
immediately without blocking the caller’s thread._

 

Currently, we call WebClient.doInvokeAsync(...) which calls 
prepareAsyncClient(...) which calls doRunInterceptorChain(...) - all on the 
main client thread. As a result the filters on the outbound chain get executed 
on the same thread which breaks the test.

I wrote a simpler test case that similarly breaks, but could use some help with 
how to implement the fix:

 

    public static class ThreadCheckFilter implements ClientRequestFilter {

        @Override

        public void filter(ClientRequestContext context) throws IOException {

            final Thread currentThread = Thread.currentThread();

            context.abortWith(Response.ok(currentThread.getName())

                                       .header("ThreadID", 
currentThread.getId())

                                       .build());

        }

    }

 

    @Test

    public void 
testClientRequestFilterRunsOnSepaarateThreadWhenInvokedAsynchronously() throws 
Exception {

        final Thread currentThread = Thread.currentThread();

        Client client = ClientBuilder.newClient();

        client.register(ThreadCheckFilter.class);

        WebTarget target = client.target("http://localhost:8080/notReal";);

        AsyncInvoker invoker = target.request().async();

        Future<Response> future = invoker.get();

        Response response = future.get();

        assertNotEquals(currentThread.getName(), 
response.readEntity(String.class));

        assertNotEquals(currentThread.getId(), 
Long.parseLong(response.getHeaderString("ThreadID")));

    }



--
This message was sent by Atlassian JIRA
(v7.6.3#76005)

Reply via email to