fix remove handler cause ByteToMessageDecoder out disorder (#9670)
Motivation: Data flowing in from the decoder flows out in sequence,Whether decoder removed or not. Modification: fire data in out and clear out when hander removed before call method handlerRemoved(ctx) Result: Fixes #9668 .
This commit is contained in:
parent
c25eec0658
commit
402537cab0
@ -499,6 +499,8 @@ public abstract class ByteToMessageDecoder extends ChannelHandlerAdapter impleme
|
|||||||
boolean removePending = decodeState == STATE_HANDLER_REMOVED_PENDING;
|
boolean removePending = decodeState == STATE_HANDLER_REMOVED_PENDING;
|
||||||
decodeState = STATE_INIT;
|
decodeState = STATE_INIT;
|
||||||
if (removePending) {
|
if (removePending) {
|
||||||
|
fireChannelRead(ctx, out, out.size());
|
||||||
|
out.clear();
|
||||||
handlerRemoved(ctx);
|
handlerRemoved(ctx);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -399,4 +399,31 @@ public class ByteToMessageDecoderTest {
|
|||||||
}
|
}
|
||||||
assertFalse(channel.finish());
|
assertFalse(channel.finish());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testDisorder() {
|
||||||
|
ByteToMessageDecoder decoder = new ByteToMessageDecoder() {
|
||||||
|
int count;
|
||||||
|
|
||||||
|
//read 4 byte then remove this decoder
|
||||||
|
@Override
|
||||||
|
protected void decode(ChannelHandlerContext ctx, ByteBuf in, List<Object> out) {
|
||||||
|
out.add(in.readByte());
|
||||||
|
if (++count >= 4) {
|
||||||
|
ctx.pipeline().remove(this);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
EmbeddedChannel channel = new EmbeddedChannel(decoder);
|
||||||
|
assertTrue(channel.writeInbound(Unpooled.wrappedBuffer(new byte[]{1, 2, 3, 4, 5})));
|
||||||
|
assertEquals((byte) 1, (byte) channel.readInbound());
|
||||||
|
assertEquals((byte) 2, (byte) channel.readInbound());
|
||||||
|
assertEquals((byte) 3, (byte) channel.readInbound());
|
||||||
|
assertEquals((byte) 4, (byte) channel.readInbound());
|
||||||
|
ByteBuf buffer5 = channel.readInbound();
|
||||||
|
assertEquals((byte) 5, buffer5.readByte());
|
||||||
|
assertFalse(buffer5.isReadable());
|
||||||
|
assertTrue(buffer5.release());
|
||||||
|
assertFalse(channel.finish());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user