Correctly release all buffers in UnpooledTest

Motivation:

We not correctly released all buffers in the UnpooledTest and so showed "bad" way of handling buffers to people that inspect our code to understand when a buffer needs to be released.

Modifications:

Explicit release all buffers.

Result:

Cleaner and more correct code.
This commit is contained in:
Norman Maurer 2017-04-18 19:51:24 +02:00
parent 8b13d9656a
commit b662afeece

View File

@ -15,20 +15,17 @@
*/
package io.netty.buffer;
import org.junit.After;
import org.junit.Test;
import org.mockito.Mockito;
import java.io.InputStream;
import java.nio.ByteBuffer;
import java.nio.channels.ScatteringByteChannel;
import java.util.ArrayDeque;
import java.util.ArrayList;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Queue;
import static io.netty.buffer.Unpooled.*;
import static io.netty.util.internal.EmptyArrays.*;
@ -42,27 +39,6 @@ public class UnpooledTest {
private static final ByteBuf[] EMPTY_BYTE_BUFS = new ByteBuf[0];
private static final byte[][] EMPTY_BYTES_2D = new byte[0][];
private static final Queue<ByteBuf> freeLaterQueue = new ArrayDeque<ByteBuf>();
protected ByteBuf freeLater(ByteBuf buf) {
freeLaterQueue.add(buf);
return buf;
}
@After
public void tearDown() {
for (;;) {
ByteBuf buf = freeLaterQueue.poll();
if (buf == null) {
break;
}
if (buf.refCnt() > 0) {
buf.release(buf.refCnt());
}
}
}
@Test
public void testCompositeWrappedBuffer() {
ByteBuf header = buffer(12);
@ -95,9 +71,11 @@ public class UnpooledTest {
map.put(new byte[] { -1, -1, -1, (byte) 0xE1 }, 1);
for (Entry<byte[], Integer> e: map.entrySet()) {
ByteBuf buffer = wrappedBuffer(e.getKey());
assertEquals(
e.getValue().intValue(),
ByteBufUtil.hashCode(wrappedBuffer(e.getKey())));
ByteBufUtil.hashCode(buffer));
buffer.release();
}
}
@ -109,46 +87,64 @@ public class UnpooledTest {
a = wrappedBuffer(new byte[] { 1 });
b = wrappedBuffer(new byte[] { 1, 2 });
assertFalse(ByteBufUtil.equals(a, b));
a.release();
b.release();
// Same content, same firstIndex, short length.
a = wrappedBuffer(new byte[] { 1, 2, 3 });
b = wrappedBuffer(new byte[] { 1, 2, 3 });
assertTrue(ByteBufUtil.equals(a, b));
a.release();
b.release();
// Same content, different firstIndex, short length.
a = wrappedBuffer(new byte[] { 1, 2, 3 });
b = wrappedBuffer(new byte[] { 0, 1, 2, 3, 4 }, 1, 3);
assertTrue(ByteBufUtil.equals(a, b));
a.release();
b.release();
// Different content, same firstIndex, short length.
a = wrappedBuffer(new byte[] { 1, 2, 3 });
b = wrappedBuffer(new byte[] { 1, 2, 4 });
assertFalse(ByteBufUtil.equals(a, b));
a.release();
b.release();
// Different content, different firstIndex, short length.
a = wrappedBuffer(new byte[] { 1, 2, 3 });
b = wrappedBuffer(new byte[] { 0, 1, 2, 4, 5 }, 1, 3);
assertFalse(ByteBufUtil.equals(a, b));
a.release();
b.release();
// Same content, same firstIndex, long length.
a = wrappedBuffer(new byte[] { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 });
b = wrappedBuffer(new byte[] { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 });
assertTrue(ByteBufUtil.equals(a, b));
a.release();
b.release();
// Same content, different firstIndex, long length.
a = wrappedBuffer(new byte[] { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 });
b = wrappedBuffer(new byte[] { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11}, 1, 10);
assertTrue(ByteBufUtil.equals(a, b));
a.release();
b.release();
// Different content, same firstIndex, long length.
a = wrappedBuffer(new byte[] { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 });
b = wrappedBuffer(new byte[] { 1, 2, 3, 4, 6, 7, 8, 5, 9, 10 });
assertFalse(ByteBufUtil.equals(a, b));
a.release();
b.release();
// Different content, different firstIndex, long length.
a = wrappedBuffer(new byte[] { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 });
b = wrappedBuffer(new byte[] { 0, 1, 2, 3, 4, 6, 7, 8, 5, 9, 10, 11 }, 1, 10);
assertFalse(ByteBufUtil.equals(a, b));
a.release();
b.release();
}
@Test
@ -182,50 +178,55 @@ public class UnpooledTest {
}
}
}
for (ByteBuf buffer: expected) {
buffer.release();
}
}
@Test
public void shouldReturnEmptyBufferWhenLengthIsZero() {
assertSame(EMPTY_BUFFER, wrappedBuffer(EMPTY_BYTES));
assertSame(EMPTY_BUFFER, wrappedBuffer(new byte[8], 0, 0));
assertSame(EMPTY_BUFFER, wrappedBuffer(new byte[8], 8, 0));
assertSame(EMPTY_BUFFER, wrappedBuffer(ByteBuffer.allocateDirect(0)));
assertSame(EMPTY_BUFFER, wrappedBuffer(EMPTY_BUFFER));
assertSame(EMPTY_BUFFER, wrappedBuffer(EMPTY_BYTES_2D));
assertSame(EMPTY_BUFFER, wrappedBuffer(new byte[][] { EMPTY_BYTES }));
assertSame(EMPTY_BUFFER, wrappedBuffer(EMPTY_BYTE_BUFFERS));
assertSame(EMPTY_BUFFER, wrappedBuffer(new ByteBuffer[] { ByteBuffer.allocate(0) }));
assertSame(EMPTY_BUFFER, wrappedBuffer(ByteBuffer.allocate(0), ByteBuffer.allocate(0)));
assertSame(EMPTY_BUFFER, wrappedBuffer(EMPTY_BYTE_BUFS));
assertSame(EMPTY_BUFFER, wrappedBuffer(new ByteBuf[] { buffer(0) }));
assertSame(EMPTY_BUFFER, wrappedBuffer(buffer(0), buffer(0)));
assertSameAndRelease(EMPTY_BUFFER, wrappedBuffer(EMPTY_BYTES));
assertSameAndRelease(EMPTY_BUFFER, wrappedBuffer(new byte[8], 0, 0));
assertSameAndRelease(EMPTY_BUFFER, wrappedBuffer(new byte[8], 8, 0));
assertSameAndRelease(EMPTY_BUFFER, wrappedBuffer(ByteBuffer.allocateDirect(0)));
assertSameAndRelease(EMPTY_BUFFER, wrappedBuffer(EMPTY_BUFFER));
assertSameAndRelease(EMPTY_BUFFER, wrappedBuffer(EMPTY_BYTES_2D));
assertSameAndRelease(EMPTY_BUFFER, wrappedBuffer(new byte[][] { EMPTY_BYTES }));
assertSameAndRelease(EMPTY_BUFFER, wrappedBuffer(EMPTY_BYTE_BUFFERS));
assertSameAndRelease(EMPTY_BUFFER, wrappedBuffer(new ByteBuffer[] { ByteBuffer.allocate(0) }));
assertSameAndRelease(EMPTY_BUFFER, wrappedBuffer(ByteBuffer.allocate(0), ByteBuffer.allocate(0)));
assertSameAndRelease(EMPTY_BUFFER, wrappedBuffer(EMPTY_BYTE_BUFS));
assertSameAndRelease(EMPTY_BUFFER, wrappedBuffer(new ByteBuf[] { buffer(0) }));
assertSameAndRelease(EMPTY_BUFFER, wrappedBuffer(buffer(0), buffer(0)));
assertSame(EMPTY_BUFFER, copiedBuffer(EMPTY_BYTES));
assertSame(EMPTY_BUFFER, copiedBuffer(new byte[8], 0, 0));
assertSame(EMPTY_BUFFER, copiedBuffer(new byte[8], 8, 0));
assertSame(EMPTY_BUFFER, copiedBuffer(ByteBuffer.allocateDirect(0)));
assertSame(EMPTY_BUFFER, copiedBuffer(EMPTY_BUFFER));
assertSameAndRelease(EMPTY_BUFFER, copiedBuffer(EMPTY_BYTES));
assertSameAndRelease(EMPTY_BUFFER, copiedBuffer(new byte[8], 0, 0));
assertSameAndRelease(EMPTY_BUFFER, copiedBuffer(new byte[8], 8, 0));
assertSameAndRelease(EMPTY_BUFFER, copiedBuffer(ByteBuffer.allocateDirect(0)));
assertSameAndRelease(EMPTY_BUFFER, copiedBuffer(EMPTY_BUFFER));
assertSame(EMPTY_BUFFER, copiedBuffer(EMPTY_BYTES_2D));
assertSame(EMPTY_BUFFER, copiedBuffer(new byte[][] { EMPTY_BYTES }));
assertSame(EMPTY_BUFFER, copiedBuffer(EMPTY_BYTE_BUFFERS));
assertSame(EMPTY_BUFFER, copiedBuffer(new ByteBuffer[] { ByteBuffer.allocate(0) }));
assertSame(EMPTY_BUFFER, copiedBuffer(ByteBuffer.allocate(0), ByteBuffer.allocate(0)));
assertSame(EMPTY_BUFFER, copiedBuffer(EMPTY_BYTE_BUFS));
assertSame(EMPTY_BUFFER, copiedBuffer(new ByteBuf[] { buffer(0) }));
assertSame(EMPTY_BUFFER, copiedBuffer(buffer(0), buffer(0)));
assertSameAndRelease(EMPTY_BUFFER, copiedBuffer(new byte[][] { EMPTY_BYTES }));
assertSameAndRelease(EMPTY_BUFFER, copiedBuffer(EMPTY_BYTE_BUFFERS));
assertSameAndRelease(EMPTY_BUFFER, copiedBuffer(new ByteBuffer[] { ByteBuffer.allocate(0) }));
assertSameAndRelease(EMPTY_BUFFER, copiedBuffer(ByteBuffer.allocate(0), ByteBuffer.allocate(0)));
assertSameAndRelease(EMPTY_BUFFER, copiedBuffer(EMPTY_BYTE_BUFS));
assertSameAndRelease(EMPTY_BUFFER, copiedBuffer(new ByteBuf[] { buffer(0) }));
assertSameAndRelease(EMPTY_BUFFER, copiedBuffer(buffer(0), buffer(0)));
}
@Test
public void testCompare2() {
assertTrue(ByteBufUtil.compare(
wrappedBuffer(new byte[]{(byte) 0xFF, (byte) 0xFF, (byte) 0xFF, (byte) 0xFF}),
wrappedBuffer(new byte[]{(byte) 0x00, (byte) 0x00, (byte) 0x00, (byte) 0x00}))
> 0);
ByteBuf expected = wrappedBuffer(new byte[]{(byte) 0xFF, (byte) 0xFF, (byte) 0xFF, (byte) 0xFF});
ByteBuf actual = wrappedBuffer(new byte[]{(byte) 0x00, (byte) 0x00, (byte) 0x00, (byte) 0x00});
assertTrue(ByteBufUtil.compare(expected, actual) > 0);
expected.release();
actual.release();
assertTrue(ByteBufUtil.compare(
wrappedBuffer(new byte[]{(byte) 0xFF}),
wrappedBuffer(new byte[]{(byte) 0x00}))
> 0);
expected = wrappedBuffer(new byte[]{(byte) 0xFF});
actual = wrappedBuffer(new byte[]{(byte) 0x00});
assertTrue(ByteBufUtil.compare(expected, actual) > 0);
expected.release();
actual.release();
}
@Test
@ -243,44 +244,32 @@ public class UnpooledTest {
@Test
public void testWrappedBuffer() {
assertEquals(16, freeLater(wrappedBuffer(ByteBuffer.allocateDirect(16))).capacity());
ByteBuf buffer = wrappedBuffer(ByteBuffer.allocateDirect(16));
assertEquals(16, buffer.capacity());
buffer.release();
assertEquals(
assertEqualsAndRelease(
wrappedBuffer(new byte[] { 1, 2, 3 }),
wrappedBuffer(new byte[][] { new byte[] { 1, 2, 3 } }));
assertEquals(
assertEqualsAndRelease(
wrappedBuffer(new byte[] { 1, 2, 3 }),
freeLater(wrappedBuffer(
new byte[] { 1 },
new byte[] { 2 },
new byte[] { 3 })));
wrappedBuffer(new byte[] { 1 }, new byte[] { 2 }, new byte[] { 3 }));
assertEquals(
wrappedBuffer(new byte[] { 1, 2, 3 }),
wrappedBuffer(new ByteBuf[] {
wrappedBuffer(new byte[] { 1, 2, 3 })
}));
assertEqualsAndRelease(wrappedBuffer(new byte[] { 1, 2, 3 }),
wrappedBuffer(new ByteBuf[] { wrappedBuffer(new byte[] { 1, 2, 3 }) }));
assertEquals(
assertEqualsAndRelease(
wrappedBuffer(new byte[] { 1, 2, 3 }),
freeLater(wrappedBuffer(
wrappedBuffer(new byte[] { 1 }),
wrappedBuffer(new byte[] { 2 }),
wrappedBuffer(new byte[] { 3 }))));
wrappedBuffer(wrappedBuffer(new byte[] { 1 }),
wrappedBuffer(new byte[] { 2 }), wrappedBuffer(new byte[] { 3 })));
assertEquals(
wrappedBuffer(new byte[] { 1, 2, 3 }),
wrappedBuffer(new ByteBuffer[] {
ByteBuffer.wrap(new byte[] { 1, 2, 3 })
}));
assertEqualsAndRelease(wrappedBuffer(new byte[] { 1, 2, 3 }),
wrappedBuffer(new ByteBuffer[] { ByteBuffer.wrap(new byte[] { 1, 2, 3 }) }));
assertEquals(
wrappedBuffer(new byte[] { 1, 2, 3 }),
freeLater(wrappedBuffer(
ByteBuffer.wrap(new byte[] { 1 }),
ByteBuffer.wrap(new byte[] { 2 }),
ByteBuffer.wrap(new byte[] { 3 }))));
assertEqualsAndRelease(wrappedBuffer(new byte[] { 1, 2, 3 }),
wrappedBuffer(ByteBuffer.wrap(new byte[] { 1 }),
ByteBuffer.wrap(new byte[] { 2 }), ByteBuffer.wrap(new byte[] { 3 })));
}
@Test
@ -321,60 +310,57 @@ public class UnpooledTest {
@Test
public void testCopiedBuffer() {
assertEquals(16, copiedBuffer(ByteBuffer.allocateDirect(16)).capacity());
ByteBuf copied = copiedBuffer(ByteBuffer.allocateDirect(16));
assertEquals(16, copied.capacity());
copied.release();
assertEquals(
wrappedBuffer(new byte[] { 1, 2, 3 }),
assertEqualsAndRelease(wrappedBuffer(new byte[] { 1, 2, 3 }),
copiedBuffer(new byte[][] { new byte[] { 1, 2, 3 } }));
assertEquals(
wrappedBuffer(new byte[] { 1, 2, 3 }),
copiedBuffer(
new byte[] { 1 },
new byte[] { 2 },
new byte[] { 3 }));
assertEqualsAndRelease(wrappedBuffer(new byte[] { 1, 2, 3 }),
copiedBuffer(new byte[] { 1 }, new byte[] { 2 }, new byte[] { 3 }));
assertEquals(
wrappedBuffer(new byte[] { 1, 2, 3 }),
copiedBuffer(new ByteBuf[] {
wrappedBuffer(new byte[] { 1, 2, 3 })
}));
assertEqualsAndRelease(wrappedBuffer(new byte[] { 1, 2, 3 }),
copiedBuffer(new ByteBuf[] { wrappedBuffer(new byte[] { 1, 2, 3 })}));
assertEquals(
wrappedBuffer(new byte[] { 1, 2, 3 }),
copiedBuffer(
wrappedBuffer(new byte[] { 1 }),
wrappedBuffer(new byte[] { 2 }),
wrappedBuffer(new byte[] { 3 })));
assertEqualsAndRelease(wrappedBuffer(new byte[] { 1, 2, 3 }),
copiedBuffer(wrappedBuffer(new byte[] { 1 }),
wrappedBuffer(new byte[] { 2 }), wrappedBuffer(new byte[] { 3 })));
assertEquals(
wrappedBuffer(new byte[] { 1, 2, 3 }),
copiedBuffer(new ByteBuffer[] {
ByteBuffer.wrap(new byte[] { 1, 2, 3 })
}));
assertEqualsAndRelease(wrappedBuffer(new byte[] { 1, 2, 3 }),
copiedBuffer(new ByteBuffer[] { ByteBuffer.wrap(new byte[] { 1, 2, 3 }) }));
assertEquals(
wrappedBuffer(new byte[] { 1, 2, 3 }),
copiedBuffer(
ByteBuffer.wrap(new byte[] { 1 }),
ByteBuffer.wrap(new byte[] { 2 }),
ByteBuffer.wrap(new byte[] { 3 })));
assertEqualsAndRelease(wrappedBuffer(new byte[] { 1, 2, 3 }),
copiedBuffer(ByteBuffer.wrap(new byte[] { 1 }),
ByteBuffer.wrap(new byte[] { 2 }), ByteBuffer.wrap(new byte[] { 3 })));
}
private static void assertEqualsAndRelease(ByteBuf expected, ByteBuf actual) {
assertEquals(expected, actual);
expected.release();
actual.release();
}
private static void assertSameAndRelease(ByteBuf expected, ByteBuf actual) {
assertEquals(expected, actual);
expected.release();
actual.release();
}
@Test
public void testHexDump() {
assertEquals("", ByteBufUtil.hexDump(EMPTY_BUFFER));
assertEquals("123456", ByteBufUtil.hexDump(wrappedBuffer(
new byte[]{
0x12, 0x34, 0x56
})));
ByteBuf buffer = wrappedBuffer(new byte[]{ 0x12, 0x34, 0x56 });
assertEquals("123456", ByteBufUtil.hexDump(buffer));
buffer.release();
assertEquals("1234567890abcdef", ByteBufUtil.hexDump(wrappedBuffer(
new byte[]{
0x12, 0x34, 0x56, 0x78,
(byte) 0x90, (byte) 0xAB, (byte) 0xCD, (byte) 0xEF
})));
buffer = wrappedBuffer(new byte[]{
0x12, 0x34, 0x56, 0x78,
(byte) 0x90, (byte) 0xAB, (byte) 0xCD, (byte) 0xEF
});
assertEquals("1234567890abcdef", ByteBufUtil.hexDump(buffer));
buffer.release();
}
@Test
@ -467,6 +453,7 @@ public class UnpooledTest {
// Expected
}
Mockito.verifyZeroInteractions(scatteringByteChannel);
buf.release();
}
@Test
@ -475,6 +462,7 @@ public class UnpooledTest {
assertEquals(4, buffer.capacity());
assertEquals(42, buffer.readInt());
assertFalse(buffer.isReadable());
buffer.release();
}
@Test
@ -484,9 +472,15 @@ public class UnpooledTest {
assertEquals(1, buffer.readInt());
assertEquals(4, buffer.readInt());
assertFalse(buffer.isReadable());
buffer.release();
assertEquals(0, copyInt(null).capacity());
assertEquals(0, copyInt(new int[] {}).capacity());
buffer = copyInt(null);
assertEquals(0, buffer.capacity());
buffer.release();
buffer = copyInt(new int[] {});
assertEquals(0, buffer.capacity());
buffer.release();
}
@Test
@ -495,6 +489,7 @@ public class UnpooledTest {
assertEquals(2, buffer.capacity());
assertEquals(42, buffer.readShort());
assertFalse(buffer.isReadable());
buffer.release();
}
@Test
@ -504,9 +499,15 @@ public class UnpooledTest {
assertEquals(1, buffer.readShort());
assertEquals(4, buffer.readShort());
assertFalse(buffer.isReadable());
buffer.release();
assertEquals(0, copyShort((short[]) null).capacity());
assertEquals(0, copyShort(new short[] {}).capacity());
buffer = copyShort((short[]) null);
assertEquals(0, buffer.capacity());
buffer.release();
buffer = copyShort(new short[] {});
assertEquals(0, buffer.capacity());
buffer.release();
}
@Test
@ -516,9 +517,15 @@ public class UnpooledTest {
assertEquals(1, buffer.readShort());
assertEquals(4, buffer.readShort());
assertFalse(buffer.isReadable());
buffer.release();
assertEquals(0, copyShort((int[]) null).capacity());
assertEquals(0, copyShort(new int[] {}).capacity());
buffer = copyShort((int[]) null);
assertEquals(0, buffer.capacity());
buffer.release();
buffer = copyShort(new int[] {});
assertEquals(0, buffer.capacity());
buffer.release();
}
@Test
@ -527,6 +534,7 @@ public class UnpooledTest {
assertEquals(3, buffer.capacity());
assertEquals(42, buffer.readMedium());
assertFalse(buffer.isReadable());
buffer.release();
}
@Test
@ -536,9 +544,15 @@ public class UnpooledTest {
assertEquals(1, buffer.readMedium());
assertEquals(4, buffer.readMedium());
assertFalse(buffer.isReadable());
buffer.release();
buffer = copyMedium(null);
assertEquals(0, copyMedium(null).capacity());
assertEquals(0, copyMedium(new int[] {}).capacity());
buffer.release();
buffer = copyMedium(new int[] {});
assertEquals(0, buffer.capacity());
buffer.release();
}
@Test
@ -547,6 +561,7 @@ public class UnpooledTest {
assertEquals(8, buffer.capacity());
assertEquals(42, buffer.readLong());
assertFalse(buffer.isReadable());
buffer.release();
}
@Test
@ -556,9 +571,15 @@ public class UnpooledTest {
assertEquals(1, buffer.readLong());
assertEquals(4, buffer.readLong());
assertFalse(buffer.isReadable());
buffer.release();
assertEquals(0, copyLong(null).capacity());
assertEquals(0, copyLong(new long[] {}).capacity());
buffer = copyLong(null);
assertEquals(0, buffer.capacity());
buffer.release();
buffer = copyLong(new long[] {});
assertEquals(0, buffer.capacity());
buffer.release();
}
@Test
@ -567,6 +588,7 @@ public class UnpooledTest {
assertEquals(4, buffer.capacity());
assertEquals(42, buffer.readFloat(), 0.01);
assertFalse(buffer.isReadable());
buffer.release();
}
@Test
@ -576,9 +598,15 @@ public class UnpooledTest {
assertEquals(1, buffer.readFloat(), 0.01);
assertEquals(4, buffer.readFloat(), 0.01);
assertFalse(buffer.isReadable());
buffer.release();
assertEquals(0, copyFloat(null).capacity());
assertEquals(0, copyFloat(new float[] {}).capacity());
buffer = copyFloat(null);
assertEquals(0, buffer.capacity());
buffer.release();
buffer = copyFloat(new float[] {});
assertEquals(0, buffer.capacity());
buffer.release();
}
@Test
@ -587,6 +615,7 @@ public class UnpooledTest {
assertEquals(8, buffer.capacity());
assertEquals(42, buffer.readDouble(), 0.01);
assertFalse(buffer.isReadable());
buffer.release();
}
@Test
@ -596,9 +625,15 @@ public class UnpooledTest {
assertEquals(1, buffer.readDouble(), 0.01);
assertEquals(4, buffer.readDouble(), 0.01);
assertFalse(buffer.isReadable());
buffer.release();
assertEquals(0, copyDouble(null).capacity());
assertEquals(0, copyDouble(new double[] {}).capacity());
buffer = copyDouble(null);
assertEquals(0, buffer.capacity());
buffer.release();
buffer = copyDouble(new double[] {});
assertEquals(0, buffer.capacity());
buffer.release();
}
@Test
@ -608,9 +643,15 @@ public class UnpooledTest {
assertTrue(buffer.readBoolean());
assertFalse(buffer.readBoolean());
assertFalse(buffer.isReadable());
buffer.release();
assertEquals(0, copyBoolean(null).capacity());
assertEquals(0, copyBoolean(new boolean[] {}).capacity());
buffer = copyBoolean(null);
assertEquals(0, buffer.capacity());
buffer.release();
buffer = copyBoolean(new boolean[] {});
assertEquals(0, buffer.capacity());
buffer.release();
}
@Test
@ -629,8 +670,12 @@ public class UnpooledTest {
@Test(expected = IllegalArgumentException.class)
public void skipBytesNegativeLength() {
ByteBuf buf = freeLater(buffer(8));
buf.skipBytes(-1);
ByteBuf buf = buffer(8);
try {
buf.skipBytes(-1);
} finally {
buf.release();
}
}
// See https://github.com/netty/netty/issues/5597