You are viewing a plain text version of this content. The canonical link for it is here.
Posted to dev@hc.apache.org by "Oleg Kalnichevski (JIRA)" <ji...@apache.org> on 2014/01/09 10:02:00 UTC

[jira] [Updated] (HTTPASYNC-64) Race condition using CachingHttpAsyncClient

     [ https://issues.apache.org/jira/browse/HTTPASYNC-64?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]

Oleg Kalnichevski updated HTTPASYNC-64:
---------------------------------------

    Fix Version/s: 4.0.1

> Race condition using CachingHttpAsyncClient
> -------------------------------------------
>
>                 Key: HTTPASYNC-64
>                 URL: https://issues.apache.org/jira/browse/HTTPASYNC-64
>             Project: HttpComponents HttpAsyncClient
>          Issue Type: Bug
>    Affects Versions: 4.0 Final
>         Environment: JDK 1.7, macbook pro
>            Reporter: Rahul 
>              Labels: CachingHttpAsyncClient, FutureHttpResponse, concurrency, race-condition
>             Fix For: 4.0.1
>
>
> Running into a race condition when using CachingHttpAsyncClient. The async client at times returns null from the FutureHttpResponse obtained from CachingHttpAsyncClient.execute(HttpGet, null)
> In FutureHttpResponse the get() method has the following implementation - 
> try {
>             getDelegate().get();
>         } catch (ExecutionException e) {
>             // ignore
>         }
>         final HttpResponse result = getResponse();
> When the getDelegate().get(); returns, the getResponse() returns null. It seems the thread doing the actual request/response processing still hasn't called "setResponse". 



--
This message was sent by Atlassian JIRA
(v6.1.5#6160)

---------------------------------------------------------------------
To unsubscribe, e-mail: dev-unsubscribe@hc.apache.org
For additional commands, e-mail: dev-help@hc.apache.org