82 lines
3.0 KiB
Java
82 lines
3.0 KiB
Java
package fr.xephi.authme.settings;
|
|
|
|
import fr.xephi.authme.AuthMe;
|
|
import fr.xephi.authme.TestHelper;
|
|
import fr.xephi.authme.security.HashAlgorithm;
|
|
import fr.xephi.authme.service.BukkitService;
|
|
import fr.xephi.authme.settings.properties.EmailSettings;
|
|
import fr.xephi.authme.settings.properties.HooksSettings;
|
|
import fr.xephi.authme.settings.properties.PluginSettings;
|
|
import fr.xephi.authme.settings.properties.RestrictionSettings;
|
|
import fr.xephi.authme.settings.properties.SecuritySettings;
|
|
import org.junit.Test;
|
|
import org.junit.runner.RunWith;
|
|
import org.mockito.InjectMocks;
|
|
import org.mockito.Mock;
|
|
import org.mockito.junit.MockitoJUnitRunner;
|
|
|
|
import java.util.Optional;
|
|
import java.util.logging.Logger;
|
|
|
|
import static org.mockito.ArgumentMatchers.anyString;
|
|
import static org.mockito.BDDMockito.given;
|
|
import static org.mockito.Mockito.verify;
|
|
import static org.mockito.Mockito.verifyNoInteractions;
|
|
import static org.mockito.internal.verification.VerificationModeFactory.times;
|
|
|
|
/**
|
|
* Test for {@link SettingsWarner}.
|
|
*/
|
|
@RunWith(MockitoJUnitRunner.class)
|
|
public class SettingsWarnerTest {
|
|
|
|
@InjectMocks
|
|
private SettingsWarner settingsWarner;
|
|
|
|
@Mock
|
|
private Settings settings;
|
|
|
|
@Mock
|
|
private AuthMe authMe;
|
|
|
|
@Mock
|
|
private BukkitService bukkitService;
|
|
|
|
@Test
|
|
public void shouldLogWarnings() {
|
|
// given
|
|
Logger logger = TestHelper.setupLogger();
|
|
given(settings.getProperty(RestrictionSettings.FORCE_SINGLE_SESSION)).willReturn(false);
|
|
given(settings.getProperty(EmailSettings.SMTP_PORT)).willReturn(44);
|
|
given(settings.getProperty(EmailSettings.PORT25_USE_TLS)).willReturn(false);
|
|
given(settings.getProperty(PluginSettings.SESSIONS_ENABLED)).willReturn(true);
|
|
given(settings.getProperty(PluginSettings.SESSIONS_TIMEOUT)).willReturn(-5);
|
|
given(settings.getProperty(SecuritySettings.PASSWORD_HASH)).willReturn(HashAlgorithm.BCRYPT);
|
|
given(settings.getProperty(HooksSettings.BUNGEECORD)).willReturn(false);
|
|
given(bukkitService.isBungeeCordConfiguredForSpigot()).willReturn(true);
|
|
|
|
// when
|
|
settingsWarner.logWarningsForMisconfigurations();
|
|
|
|
// then
|
|
verify(logger, times(4)).warning(anyString());
|
|
}
|
|
|
|
@Test
|
|
public void shouldNotLogAnyWarning() {
|
|
Logger logger = TestHelper.setupLogger();
|
|
given(settings.getProperty(RestrictionSettings.FORCE_SINGLE_SESSION)).willReturn(true);
|
|
given(settings.getProperty(EmailSettings.SMTP_PORT)).willReturn(25);
|
|
given(settings.getProperty(EmailSettings.PORT25_USE_TLS)).willReturn(false);
|
|
given(settings.getProperty(PluginSettings.SESSIONS_ENABLED)).willReturn(false);
|
|
given(settings.getProperty(SecuritySettings.PASSWORD_HASH)).willReturn(HashAlgorithm.MD5);
|
|
given(bukkitService.isBungeeCordConfiguredForSpigot()).willReturn(false);
|
|
|
|
// when
|
|
settingsWarner.logWarningsForMisconfigurations();
|
|
|
|
// then
|
|
verifyNoInteractions(logger);
|
|
}
|
|
}
|