You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

LdapAutoDiscoveryWarningLogTest.java 4.3KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. /*
  2. * SonarQube
  3. * Copyright (C) 2009-2020 SonarSource SA
  4. * mailto:info AT sonarsource DOT com
  5. *
  6. * This program is free software; you can redistribute it and/or
  7. * modify it under the terms of the GNU Lesser General Public
  8. * License as published by the Free Software Foundation; either
  9. * version 3 of the License, or (at your option) any later version.
  10. *
  11. * This program is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  14. * Lesser General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU Lesser General Public License
  17. * along with this program; if not, write to the Free Software Foundation,
  18. * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
  19. */
  20. package org.sonar.auth.ldap;
  21. import org.junit.ClassRule;
  22. import org.junit.Rule;
  23. import org.junit.Test;
  24. import org.sonar.api.config.internal.MapSettings;
  25. import org.sonar.api.utils.log.LogTester;
  26. import org.sonar.api.utils.log.LoggerLevel;
  27. import org.sonar.auth.ldap.server.ApacheDS;
  28. import org.sonar.auth.ldap.server.LdapServer;
  29. import static java.util.Collections.singletonList;
  30. import static org.assertj.core.api.Assertions.assertThat;
  31. import static org.mockito.Mockito.mock;
  32. import static org.mockito.Mockito.when;
  33. public class LdapAutoDiscoveryWarningLogTest {
  34. @Rule
  35. public LogTester logTester = new LogTester();
  36. @ClassRule
  37. public static LdapServer server = new LdapServer("/users.example.org.ldif");
  38. @Test
  39. public void does_not_display_log_when_not_using_auto_discovery() {
  40. MapSettings settings = new MapSettings()
  41. .setProperty("ldap.url", server.getUrl());
  42. LdapRealm realm = new LdapRealm(new LdapSettingsManager(settings.asConfig(), new LdapAutodiscovery()));
  43. assertThat(realm.getName()).isEqualTo("LDAP");
  44. realm.init();
  45. assertThat(logTester.logs(LoggerLevel.WARN)).isEmpty();
  46. }
  47. @Test
  48. public void display_warning_log_when_using_auto_discovery_to_detect_server_url() {
  49. LdapAutodiscovery ldapAutodiscovery = mock(LdapAutodiscovery.class);
  50. when(ldapAutodiscovery.getLdapServers("example.org")).thenReturn(singletonList(new LdapAutodiscovery.LdapSrvRecord(server.getUrl(), 1, 1)));
  51. // ldap.url setting is not set
  52. LdapRealm realm = new LdapRealm(new LdapSettingsManager(new MapSettings().setProperty("ldap.realm", "example.org").asConfig(),
  53. ldapAutodiscovery));
  54. realm.init();
  55. assertThat(logTester.logs(LoggerLevel.WARN)).contains("Auto-discovery feature is deprecated, please use 'ldap.url' to specify LDAP url");
  56. }
  57. @Test
  58. public void display_warning_log_when_using_auto_discovery_to_detect_user_baseDn_on_single_server() {
  59. // ldap.user.baseDn setting is not set
  60. MapSettings settings = new MapSettings().setProperty("ldap.url", server.getUrl()).setProperty("ldap.realm", "example.org");
  61. LdapRealm realm = new LdapRealm(new LdapSettingsManager(settings.asConfig(), new LdapAutodiscovery()));
  62. realm.init();
  63. assertThat(logTester.logs(LoggerLevel.WARN)).containsOnly("Auto-discovery feature is deprecated, please use 'ldap.user.baseDn' to specify user search dn");
  64. }
  65. @Test
  66. public void display_warning_log_when_using_auto_discovery_to_detect_user_baseDn_on_multiple_servers() throws Exception {
  67. ApacheDS server2 = ApacheDS.start("example.org", "dc=example,dc=org", "target/ldap-work2/");
  68. server2.importLdif(LdapAutoDiscoveryWarningLogTest.class.getResourceAsStream("/users.example.org.ldif"));
  69. MapSettings settings = new MapSettings()
  70. .setProperty("ldap.servers", "example,infosupport")
  71. // ldap.XXX.user.baseDn settings are not set on both servers
  72. .setProperty("ldap.example.url", server.getUrl())
  73. .setProperty("ldap.example.realm", "example.org")
  74. .setProperty("ldap.infosupport.url", server2.getUrl())
  75. .setProperty("ldap.infosupport.realm", "infosupport.org");
  76. LdapRealm realm = new LdapRealm(new LdapSettingsManager(settings.asConfig(), new LdapAutodiscovery()));
  77. realm.init();
  78. assertThat(logTester.logs(LoggerLevel.WARN)).containsOnly(
  79. "Auto-discovery feature is deprecated, please use 'ldap.example.user.baseDn' to specify user search dn",
  80. "Auto-discovery feature is deprecated, please use 'ldap.infosupport.user.baseDn' to specify user search dn");
  81. }
  82. }