[
https://issues.apache.org/jira/browse/HTTPCLIENT-2291?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
]
Lars Uffmann updated HTTPCLIENT-2291:
-------------------------------------
Component/s: HttpClient (async)
HttpClient (classic)
Affects Version/s: 5.2
Description:
A RetryStrategy is enabled by default in both classic and async.
If an exec chain handler is placed *after* the retry handler, the behavior
between async and classic is consistent. The behavior of an Async- and a
classic ExecChainHandler placed *before* the (Async)HttpRequestRetryExec is
different when a retry is actually executed.
In case of a retry, the classic HttpRequestRetryExec will split the exec chain
and proceed with all handlers configured after itself. Any handler registered
before would be called exactly one time with the final outcome of the last
retry attempt.
The Async version, however, will call any handler registered before itself with
every retry. The order of events is counter intuitive as well. All closing
events will be emitted after the last attempt.
{*}Workaround{*}: In async, ignore all but the first invocation of a handler
when the handler is placed before the retry handler.
{*}Expected Bahaviour{*}: Both Async and Classic ExecChainHandler behavior
should be identical.
was:Async and
Summary: RetryStrategy: AsyncExecChainHandler and
ExecChainHandler behavior should be identical (was: RetryStrategy:
AsyncExecChainHandler and ExecChainHandler behavior should be equalized)
> RetryStrategy: AsyncExecChainHandler and ExecChainHandler behavior should be
> identical
> --------------------------------------------------------------------------------------
>
> Key: HTTPCLIENT-2291
> URL: https://issues.apache.org/jira/browse/HTTPCLIENT-2291
> Project: HttpComponents HttpClient
> Issue Type: Improvement
> Components: HttpClient (async), HttpClient (classic)
> Affects Versions: 5.2
> Reporter: Lars Uffmann
> Priority: Major
>
> A RetryStrategy is enabled by default in both classic and async.
>
> If an exec chain handler is placed *after* the retry handler, the behavior
> between async and classic is consistent. The behavior of an Async- and a
> classic ExecChainHandler placed *before* the (Async)HttpRequestRetryExec is
> different when a retry is actually executed.
>
> In case of a retry, the classic HttpRequestRetryExec will split the exec
> chain and proceed with all handlers configured after itself. Any handler
> registered before would be called exactly one time with the final outcome of
> the last retry attempt.
>
> The Async version, however, will call any handler registered before itself
> with every retry. The order of events is counter intuitive as well. All
> closing events will be emitted after the last attempt.
>
> {*}Workaround{*}: In async, ignore all but the first invocation of a handler
> when the handler is placed before the retry handler.
>
> {*}Expected Bahaviour{*}: Both Async and Classic ExecChainHandler behavior
> should be identical.
--
This message was sent by Atlassian Jira
(v8.20.10#820010)
---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]