Skip to content

Commit

Permalink
Merge pull request #5716 from fjuma/WFCORE-6538
Browse files Browse the repository at this point in the history
[WFCORE-6538] ClosedChannelException is thrown intermittently instead of SaslException when using GS2_KRB5 with TLS
  • Loading branch information
yersan authored Oct 12, 2023
2 parents 0992209 + 4bda982 commit a66a84f
Showing 1 changed file with 32 additions and 13 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@
import java.io.IOException;
import java.net.ConnectException;
import java.net.MalformedURLException;
import java.nio.channels.ClosedChannelException;
import java.nio.charset.StandardCharsets;
import java.nio.file.Files;
import java.security.GeneralSecurityException;
Expand Down Expand Up @@ -341,19 +342,37 @@ protected void assertAuthenticationFails(String message, Class<? extends Excepti
if (message == null) {
message = "The failure of :whoami operation execution was expected, but the call passed";
}
final long startTime = System.currentTimeMillis();
try {
executeWhoAmI(withTls);
fail(message);
} catch (IOException | GeneralSecurityException e) {
assertTrue("Connection reached its timeout (hang).",
startTime + CONNECTION_TIMEOUT_IN_MS > System.currentTimeMillis());
Throwable cause = e.getCause();
assertThat("ConnectionException was expected as a cause when authentication fails", cause,
is(instanceOf(ConnectException.class)));
assertThat("Unexpected type of inherited exception for authentication failure", cause.getCause(),
anyOf(is(instanceOf(SSLException.class)), is(instanceOf(SaslException.class)),
is(instanceOf(RedirectException.class))));

// Work around a known issue with SSLEngine that intermittently results
// in a ClosedChannelException instead of the expected exception.
// When this happens, execute the whoAmI operation again because the
// probability of hitting a ClosedChannelException a second time
// is very small. In the event that a ClosedChannelException is
// erroneously occurring multiple times, it will fail in the second
// run as well. See WFCORE-6538 for more details.
for (int i = 0; i < 2; i++) {
final long startTime = System.currentTimeMillis();
try {
executeWhoAmI(withTls);
fail(message);
} catch (IOException | GeneralSecurityException e) {
assertTrue("Connection reached its timeout (hang).",
startTime + CONNECTION_TIMEOUT_IN_MS > System.currentTimeMillis());
Throwable cause = e.getCause();
assertThat("ConnectionException was expected as a cause when authentication fails", cause,
is(instanceOf(ConnectException.class)));

// if execution ends with ClosedChannelException during first run, run once again
if (i == 0 && cause.getCause() instanceof ClosedChannelException) {
LOGGER.warn("ClosedChannelException detected, probably because of the bug in SSLEngine. Because this happens very rarely, attempt to execute the op again");
continue;
}
assertThat("Unexpected type of inherited exception for authentication failure", cause.getCause(),
anyOf(is(instanceOf(SSLException.class)), is(instanceOf(SaslException.class)),
is(instanceOf(RedirectException.class))));
}
// if execution succeeds, there is no need to run again
break;
}
}

Expand Down

0 comments on commit a66a84f

Please sign in to comment.