Make sure PrematureChannelClosureException is not thrown incorrectly sometimes. See #266
This commit is contained in:
parent
ff5787266d
commit
b1c2771801
@ -125,20 +125,27 @@ public class HttpClientCodec implements ChannelUpstreamHandler,
|
|||||||
return buffer.readBytes(actualReadableBytes());
|
return buffer.readBytes(actualReadableBytes());
|
||||||
} else {
|
} else {
|
||||||
Object msg = super.decode(ctx, channel, buffer, state);
|
Object msg = super.decode(ctx, channel, buffer, state);
|
||||||
|
decrement(msg);
|
||||||
if (msg != null) {
|
|
||||||
// check if its a HttpMessage and its not chunked
|
|
||||||
if (msg instanceof HttpMessage && !((HttpMessage) msg).isChunked()) {
|
|
||||||
requestResponseCounter.decrementAndGet();
|
|
||||||
} else if (msg instanceof HttpChunk && ((HttpChunk) msg).isLast()) {
|
|
||||||
requestResponseCounter.decrementAndGet();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return msg;
|
return msg;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void decrement(Object msg) {
|
||||||
|
if (msg == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// check if its a HttpMessage and its not chunked
|
||||||
|
if (msg instanceof HttpMessage && !((HttpMessage) msg).isChunked()) {
|
||||||
|
requestResponseCounter.decrementAndGet();
|
||||||
|
} else if (msg instanceof HttpChunk && ((HttpChunk) msg).isLast()) {
|
||||||
|
requestResponseCounter.decrementAndGet();
|
||||||
|
} else if (msg instanceof Object[]) {
|
||||||
|
// we just decrement it here as we only use this if the end of the chunk is reached
|
||||||
|
// It would be more safe to check all the objects in the array but would also be slower
|
||||||
|
requestResponseCounter.decrementAndGet();
|
||||||
|
}
|
||||||
|
}
|
||||||
@Override
|
@Override
|
||||||
protected boolean isContentAlwaysEmpty(HttpMessage msg) {
|
protected boolean isContentAlwaysEmpty(HttpMessage msg) {
|
||||||
final int statusCode = ((HttpResponse) msg).getStatus().getCode();
|
final int statusCode = ((HttpResponse) msg).getStatus().getCode();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user