Skip to content

Commit

Permalink
Miscellaneous fixes for LDAP SDK v6 upgrade
Browse files Browse the repository at this point in the history
This commit makes a few changes to LDAP testing to improve
the stability of tests on UnboudID LDAP SDK v6

Backport of: elastic#79891
  • Loading branch information
tvernum committed Oct 28, 2021
1 parent e6d4fad commit 2a35c13
Show file tree
Hide file tree
Showing 4 changed files with 10 additions and 6 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -435,10 +435,11 @@ public void testLdapRealmMapsUserDNToRole() throws Exception {
PlainActionFuture<AuthenticationResult<User>> future = new PlainActionFuture<>();
ldap.authenticate(new UsernamePasswordToken("Horatio Hornblower", new SecureString(PASSWORD)), future);
final AuthenticationResult<User> result = future.actionGet();
assertThat(result.getStatus(), is(AuthenticationResult.Status.SUCCESS));
assertThat(result, notNullValue());
assertThat(result.toString(), result.getStatus(), is(AuthenticationResult.Status.SUCCESS));
User user = result.getValue();
assertThat(user, notNullValue());
assertThat(user.roles(), arrayContaining("avenger"));
assertThat(user.toString(), user.roles(), arrayContaining("avenger"));
}

/**
Expand Down Expand Up @@ -530,7 +531,8 @@ protected void loadMappings(ActionListener<List<ExpressionRoleMapping>> listener
PlainActionFuture<AuthenticationResult<User>> future = new PlainActionFuture<>();
ldap.authenticate(new UsernamePasswordToken("Horatio Hornblower", new SecureString(PASSWORD)), future);
final AuthenticationResult<User> result = future.actionGet();
assertThat(result.getStatus(), is(AuthenticationResult.Status.SUCCESS));
assertThat(result, notNullValue());
assertThat(result.toString(), result.getStatus(), is(AuthenticationResult.Status.SUCCESS));
User user = result.getValue();
assertThat(user, notNullValue());
assertThat(user.roles(), arrayContainingInAnyOrder("_user_hhornblo", "sales_admin"));
Expand Down Expand Up @@ -560,7 +562,8 @@ public void testLdapConnectionFailureIsTreatedAsAuthenticationFailure() throws E
PlainActionFuture<AuthenticationResult<User>> future = new PlainActionFuture<>();
ldap.authenticate(new UsernamePasswordToken(VALID_USERNAME, new SecureString(PASSWORD)), future);
final AuthenticationResult<User> result = future.actionGet();
assertThat(result.getStatus(), is(AuthenticationResult.Status.CONTINUE));
assertThat(result, notNullValue());
assertThat(result.toString(), result.getStatus(), is(AuthenticationResult.Status.CONTINUE));
assertThat(result.getValue(), nullValue());
assertThat(result.getMessage(), is("authenticate failed"));
assertThat(result.getException(), notNullValue());
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -47,7 +47,7 @@ public class SearchGroupsResolverInMemoryTests extends LdapTestCase {
@After
public void closeConnection() {
if (connection != null) {
connection.close();
connection.closeWithoutUnbind();
}
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -52,6 +52,7 @@ protected void failed(Throwable e, Description description) {
}

public void configure(InMemoryDirectoryServerConfig config) {
targetLogger.info("Configuring debug logging for LDAP server [{}]", config);
config.setLDAPDebugLogHandler(logHandler);
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -156,7 +156,7 @@ void tryConnect(InMemoryDirectoryServer ds) {
AccessController.doPrivileged((PrivilegedExceptionAction<Void>) () -> {
try (var c = ds.getConnection()) {
assertThat("Failed to connect to " + ds + " - ", c.isConnected(), is(true));
logger.info("Test connection to [{}] was successful ({})", ds, c);
logger.info("Test connection to [{}](port {}) was successful ({})", ds, ds.getListenPort(), c);
} catch (LDAPException e) {
throw new AssertionError("Failed to connect to " + ds, e);
}
Expand Down

0 comments on commit 2a35c13

Please sign in to comment.