Make EpollSocketChannelConfigTest tollerant of fd reuse race (#11552)
Motivation: We cannot control when "the system" reuses file descriptors. This makes any test that assert on the behaviour of closed file descriptors inherently racy. Modification: Allow the EpollSocketChannelConfigTest socketoption tests a few tries to get the correct assertion on the behaviour of closed socket file descriptors. Result: The EpollSocketChannelConfigTest should now be much less flaky.
This commit is contained in:
parent
6d6d2060af
commit
6c2813bdb0
6
pom.xml
6
pom.xml
@ -815,6 +815,12 @@
|
|||||||
<version>1.2.3</version>
|
<version>1.2.3</version>
|
||||||
<scope>test</scope>
|
<scope>test</scope>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>io.github.artsok</groupId>
|
||||||
|
<artifactId>rerunner-jupiter</artifactId>
|
||||||
|
<version>2.1.6</version>
|
||||||
|
<scope>test</scope>
|
||||||
|
</dependency>
|
||||||
|
|
||||||
<!-- Test dependencies for jboss marshalling encoder/decoder -->
|
<!-- Test dependencies for jboss marshalling encoder/decoder -->
|
||||||
<dependency>
|
<dependency>
|
||||||
|
@ -399,6 +399,11 @@
|
|||||||
<classifier>${tcnative.classifier}</classifier>
|
<classifier>${tcnative.classifier}</classifier>
|
||||||
<scope>test</scope>
|
<scope>test</scope>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>io.github.artsok</groupId>
|
||||||
|
<artifactId>rerunner-jupiter</artifactId>
|
||||||
|
<scope>test</scope>
|
||||||
|
</dependency>
|
||||||
</dependencies>
|
</dependencies>
|
||||||
|
|
||||||
|
|
||||||
|
@ -15,6 +15,7 @@
|
|||||||
*/
|
*/
|
||||||
package io.netty.channel.epoll;
|
package io.netty.channel.epoll;
|
||||||
|
|
||||||
|
import io.github.artsok.RepeatedIfExceptionsTest;
|
||||||
import io.netty.bootstrap.Bootstrap;
|
import io.netty.bootstrap.Bootstrap;
|
||||||
import io.netty.channel.ChannelException;
|
import io.netty.channel.ChannelException;
|
||||||
import io.netty.channel.ChannelHandler;
|
import io.netty.channel.ChannelHandler;
|
||||||
@ -137,7 +138,10 @@ public class EpollSocketChannelConfigTest {
|
|||||||
assertTrue(ch.config().isTcpQuickAck());
|
assertTrue(ch.config().isTcpQuickAck());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
// For this test to pass, we are relying on the sockets file descriptor not being reused after the socket is closed.
|
||||||
|
// This is inherently racy, so we allow getSoLinger to throw ChannelException a few of times, but eventually we do
|
||||||
|
// want to see a ClosedChannelException for the test to pass.
|
||||||
|
@RepeatedIfExceptionsTest(repeats = 4, exceptions = ChannelException.class)
|
||||||
public void testSetOptionWhenClosed() {
|
public void testSetOptionWhenClosed() {
|
||||||
ch.close().syncUninterruptibly();
|
ch.close().syncUninterruptibly();
|
||||||
try {
|
try {
|
||||||
@ -148,7 +152,10 @@ public class EpollSocketChannelConfigTest {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
// For this test to pass, we are relying on the sockets file descriptor not being reused after the socket is closed.
|
||||||
|
// This is inherently racy, so we allow getSoLinger to throw ChannelException a few of times, but eventually we do
|
||||||
|
// want to see a ClosedChannelException for the test to pass.
|
||||||
|
@RepeatedIfExceptionsTest(repeats = 4, exceptions = ChannelException.class)
|
||||||
public void testGetOptionWhenClosed() {
|
public void testGetOptionWhenClosed() {
|
||||||
ch.close().syncUninterruptibly();
|
ch.close().syncUninterruptibly();
|
||||||
try {
|
try {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user