Fix possible leaks in Http2ServerDowngraderTest

Motivation:

We need to ensure we release all ReferenceCounted objects during tests to not leak.

Modifications:

Fix possible leaks by calling release()

Result:

No more leaks in tests.
This commit is contained in:
Norman Maurer 2016-05-10 09:18:33 +02:00
parent 690ab563e7
commit 341a235fea

View File

@ -34,7 +34,6 @@ import io.netty.handler.codec.http.HttpResponseStatus;
import io.netty.handler.codec.http.HttpVersion; import io.netty.handler.codec.http.HttpVersion;
import io.netty.handler.codec.http.LastHttpContent; import io.netty.handler.codec.http.LastHttpContent;
import io.netty.util.CharsetUtil; import io.netty.util.CharsetUtil;
import io.netty.util.ReferenceCountUtil;
import org.junit.Test; import org.junit.Test;
@ -71,8 +70,12 @@ public class Http2ServerDowngraderTest {
assertFalse(headersFrame.isEndStream()); assertFalse(headersFrame.isEndStream());
Http2DataFrame dataFrame = ch.readOutbound(); Http2DataFrame dataFrame = ch.readOutbound();
try {
assertThat(dataFrame.content().toString(CharsetUtil.UTF_8), is("hello world")); assertThat(dataFrame.content().toString(CharsetUtil.UTF_8), is("hello world"));
assertTrue(dataFrame.isEndStream()); assertTrue(dataFrame.isEndStream());
} finally {
dataFrame.release();
}
assertThat(ch.readOutbound(), is(nullValue())); assertThat(ch.readOutbound(), is(nullValue()));
assertFalse(ch.finish()); assertFalse(ch.finish());
@ -112,8 +115,12 @@ public class Http2ServerDowngraderTest {
assertFalse(headersFrame.isEndStream()); assertFalse(headersFrame.isEndStream());
Http2DataFrame dataFrame = ch.readOutbound(); Http2DataFrame dataFrame = ch.readOutbound();
try {
assertThat(dataFrame.content().toString(CharsetUtil.UTF_8), is("hello world")); assertThat(dataFrame.content().toString(CharsetUtil.UTF_8), is("hello world"));
assertFalse(dataFrame.isEndStream()); assertFalse(dataFrame.isEndStream());
} finally {
dataFrame.release();
}
Http2HeadersFrame trailersFrame = ch.readOutbound(); Http2HeadersFrame trailersFrame = ch.readOutbound();
assertThat(trailersFrame.headers().get("key").toString(), is("value")); assertThat(trailersFrame.headers().get("key").toString(), is("value"));
@ -145,8 +152,12 @@ public class Http2ServerDowngraderTest {
assertTrue(ch.writeOutbound(content)); assertTrue(ch.writeOutbound(content));
Http2DataFrame dataFrame = ch.readOutbound(); Http2DataFrame dataFrame = ch.readOutbound();
try {
assertThat(dataFrame.content().toString(CharsetUtil.UTF_8), is("hello world")); assertThat(dataFrame.content().toString(CharsetUtil.UTF_8), is("hello world"));
assertFalse(dataFrame.isEndStream()); assertFalse(dataFrame.isEndStream());
} finally {
dataFrame.release();
}
assertThat(ch.readOutbound(), is(nullValue())); assertThat(ch.readOutbound(), is(nullValue()));
assertFalse(ch.finish()); assertFalse(ch.finish());
@ -159,8 +170,12 @@ public class Http2ServerDowngraderTest {
assertTrue(ch.writeOutbound(end)); assertTrue(ch.writeOutbound(end));
Http2DataFrame emptyFrame = ch.readOutbound(); Http2DataFrame emptyFrame = ch.readOutbound();
try {
assertThat(emptyFrame.content().readableBytes(), is(0)); assertThat(emptyFrame.content().readableBytes(), is(0));
assertTrue(emptyFrame.isEndStream()); assertTrue(emptyFrame.isEndStream());
} finally {
emptyFrame.release();
}
assertThat(ch.readOutbound(), is(nullValue())); assertThat(ch.readOutbound(), is(nullValue()));
assertFalse(ch.finish()); assertFalse(ch.finish());
@ -174,8 +189,12 @@ public class Http2ServerDowngraderTest {
assertTrue(ch.writeOutbound(end)); assertTrue(ch.writeOutbound(end));
Http2DataFrame dataFrame = ch.readOutbound(); Http2DataFrame dataFrame = ch.readOutbound();
try {
assertThat(dataFrame.content().toString(CharsetUtil.UTF_8), is("hello world")); assertThat(dataFrame.content().toString(CharsetUtil.UTF_8), is("hello world"));
assertTrue(dataFrame.isEndStream()); assertTrue(dataFrame.isEndStream());
} finally {
dataFrame.release();
}
assertThat(ch.readOutbound(), is(nullValue())); assertThat(ch.readOutbound(), is(nullValue()));
assertFalse(ch.finish()); assertFalse(ch.finish());
@ -207,8 +226,12 @@ public class Http2ServerDowngraderTest {
assertTrue(ch.writeOutbound(trailers)); assertTrue(ch.writeOutbound(trailers));
Http2DataFrame dataFrame = ch.readOutbound(); Http2DataFrame dataFrame = ch.readOutbound();
try {
assertThat(dataFrame.content().toString(CharsetUtil.UTF_8), is("hello world")); assertThat(dataFrame.content().toString(CharsetUtil.UTF_8), is("hello world"));
assertFalse(dataFrame.isEndStream()); assertFalse(dataFrame.isEndStream());
} finally {
dataFrame.release();
}
Http2HeadersFrame headerFrame = ch.readOutbound(); Http2HeadersFrame headerFrame = ch.readOutbound();
assertThat(headerFrame.headers().get("key").toString(), is("value")); assertThat(headerFrame.headers().get("key").toString(), is("value"));
@ -247,12 +270,15 @@ public class Http2ServerDowngraderTest {
assertTrue(ch.writeInbound(new DefaultHttp2HeadersFrame(headers, true))); assertTrue(ch.writeInbound(new DefaultHttp2HeadersFrame(headers, true)));
FullHttpRequest request = ch.readInbound(); FullHttpRequest request = ch.readInbound();
ReferenceCountUtil.releaseLater(request); try {
assertThat(request.uri(), is("/")); assertThat(request.uri(), is("/"));
assertThat(request.method(), is(HttpMethod.GET)); assertThat(request.method(), is(HttpMethod.GET));
assertThat(request.protocolVersion(), is(HttpVersion.HTTP_1_1)); assertThat(request.protocolVersion(), is(HttpVersion.HTTP_1_1));
assertThat(request.content().readableBytes(), is(0)); assertThat(request.content().readableBytes(), is(0));
assertTrue(request.trailingHeaders().isEmpty()); assertTrue(request.trailingHeaders().isEmpty());
} finally {
request.release();
}
assertThat(ch.readInbound(), is(nullValue())); assertThat(ch.readInbound(), is(nullValue()));
assertFalse(ch.finish()); assertFalse(ch.finish());
@ -266,9 +292,13 @@ public class Http2ServerDowngraderTest {
assertTrue(ch.writeInbound(new DefaultHttp2HeadersFrame(headers, true))); assertTrue(ch.writeInbound(new DefaultHttp2HeadersFrame(headers, true)));
LastHttpContent trailers = ch.readInbound(); LastHttpContent trailers = ch.readInbound();
try {
assertThat(trailers.content().readableBytes(), is(0)); assertThat(trailers.content().readableBytes(), is(0));
assertThat(trailers.trailingHeaders().get("key").toString(), is("value")); assertThat(trailers.trailingHeaders().get("key").toString(), is("value"));
assertFalse(trailers instanceof FullHttpRequest); assertFalse(trailers instanceof FullHttpRequest);
} finally {
trailers.release();
}
assertThat(ch.readInbound(), is(nullValue())); assertThat(ch.readInbound(), is(nullValue()));
assertFalse(ch.finish()); assertFalse(ch.finish());
@ -281,8 +311,12 @@ public class Http2ServerDowngraderTest {
assertTrue(ch.writeInbound(new DefaultHttp2DataFrame(hello))); assertTrue(ch.writeInbound(new DefaultHttp2DataFrame(hello)));
HttpContent content = ch.readInbound(); HttpContent content = ch.readInbound();
try {
assertThat(content.content().toString(CharsetUtil.UTF_8), is("hello world")); assertThat(content.content().toString(CharsetUtil.UTF_8), is("hello world"));
assertFalse(content instanceof LastHttpContent); assertFalse(content instanceof LastHttpContent);
} finally {
content.release();
}
assertThat(ch.readInbound(), is(nullValue())); assertThat(ch.readInbound(), is(nullValue()));
assertFalse(ch.finish()); assertFalse(ch.finish());
@ -295,8 +329,12 @@ public class Http2ServerDowngraderTest {
assertTrue(ch.writeInbound(new DefaultHttp2DataFrame(hello, true))); assertTrue(ch.writeInbound(new DefaultHttp2DataFrame(hello, true)));
LastHttpContent content = ch.readInbound(); LastHttpContent content = ch.readInbound();
try {
assertThat(content.content().toString(CharsetUtil.UTF_8), is("hello world")); assertThat(content.content().toString(CharsetUtil.UTF_8), is("hello world"));
assertTrue(content.trailingHeaders().isEmpty()); assertTrue(content.trailingHeaders().isEmpty());
} finally {
content.release();
}
assertThat(ch.readInbound(), is(nullValue())); assertThat(ch.readInbound(), is(nullValue()));
assertFalse(ch.finish()); assertFalse(ch.finish());
@ -310,8 +348,8 @@ public class Http2ServerDowngraderTest {
assertTrue(ch.writeInbound(reset)); assertTrue(ch.writeInbound(reset));
assertTrue(ch.writeInbound(goaway)); assertTrue(ch.writeInbound(goaway));
assertEquals(ch.readInbound(), reset); assertEquals(reset, ch.readInbound());
assertEquals(ch.readInbound(), goaway); assertEquals(goaway, ch.readInbound());
assertThat(ch.readInbound(), is(nullValue())); assertThat(ch.readInbound(), is(nullValue()));
assertFalse(ch.finish()); assertFalse(ch.finish());