mirror of
https://github.com/AuthMe/AuthMeReloaded.git
synced 2024-11-27 12:45:57 +01:00
#674 Create tests for purge commands and purge service
This commit is contained in:
parent
51663703ea
commit
cd1acfde1b
@ -48,11 +48,6 @@ public class PurgeService implements Reloadable {
|
|||||||
private boolean isPurging = false;
|
private boolean isPurging = false;
|
||||||
|
|
||||||
// Settings
|
// Settings
|
||||||
private boolean removeEssentialsFiles;
|
|
||||||
private boolean removePlayerDat;
|
|
||||||
private boolean removeLimitedCreativeInventories;
|
|
||||||
private boolean removeAntiXrayFiles;
|
|
||||||
private boolean removePermissions;
|
|
||||||
private int daysBeforePurge;
|
private int daysBeforePurge;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -86,7 +81,7 @@ public class PurgeService implements Reloadable {
|
|||||||
|
|
||||||
ConsoleLogger.info("Automatically purging the database...");
|
ConsoleLogger.info("Automatically purging the database...");
|
||||||
Calendar calendar = Calendar.getInstance();
|
Calendar calendar = Calendar.getInstance();
|
||||||
calendar.add(Calendar.DATE, daysBeforePurge);
|
calendar.add(Calendar.DATE, -daysBeforePurge);
|
||||||
long until = calendar.getTimeInMillis();
|
long until = calendar.getTimeInMillis();
|
||||||
|
|
||||||
runPurge(null, until);
|
runPurge(null, until);
|
||||||
@ -154,7 +149,7 @@ public class PurgeService implements Reloadable {
|
|||||||
}
|
}
|
||||||
|
|
||||||
synchronized void purgeAntiXray(Set<String> cleared) {
|
synchronized void purgeAntiXray(Set<String> cleared) {
|
||||||
if (!removeAntiXrayFiles) {
|
if (!settings.getProperty(PurgeSettings.REMOVE_ANTI_XRAY_FILE)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -178,7 +173,7 @@ public class PurgeService implements Reloadable {
|
|||||||
}
|
}
|
||||||
|
|
||||||
synchronized void purgeLimitedCreative(Set<String> cleared) {
|
synchronized void purgeLimitedCreative(Set<String> cleared) {
|
||||||
if (!removeLimitedCreativeInventories) {
|
if (!settings.getProperty(PurgeSettings.REMOVE_LIMITED_CREATIVE_INVENTORIES)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -219,7 +214,7 @@ public class PurgeService implements Reloadable {
|
|||||||
}
|
}
|
||||||
|
|
||||||
synchronized void purgeDat(Set<OfflinePlayer> cleared) {
|
synchronized void purgeDat(Set<OfflinePlayer> cleared) {
|
||||||
if (!removePlayerDat) {
|
if (!settings.getProperty(PurgeSettings.REMOVE_PLAYER_DAT)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -243,7 +238,7 @@ public class PurgeService implements Reloadable {
|
|||||||
* @param cleared List of String
|
* @param cleared List of String
|
||||||
*/
|
*/
|
||||||
synchronized void purgeEssentials(Set<OfflinePlayer> cleared) {
|
synchronized void purgeEssentials(Set<OfflinePlayer> cleared) {
|
||||||
if (!removeEssentialsFiles && !pluginHooks.isEssentialsAvailable()) {
|
if (!settings.getProperty(PurgeSettings.REMOVE_ESSENTIALS_FILES) && !pluginHooks.isEssentialsAvailable()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -272,7 +267,7 @@ public class PurgeService implements Reloadable {
|
|||||||
// TODO: What is this method for? Is it correct?
|
// TODO: What is this method for? Is it correct?
|
||||||
// TODO: Make it work with OfflinePlayers group data.
|
// TODO: Make it work with OfflinePlayers group data.
|
||||||
synchronized void purgePermissions(Set<OfflinePlayer> cleared) {
|
synchronized void purgePermissions(Set<OfflinePlayer> cleared) {
|
||||||
if (!removePermissions) {
|
if (!settings.getProperty(PurgeSettings.REMOVE_PERMISSIONS)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -294,11 +289,6 @@ public class PurgeService implements Reloadable {
|
|||||||
@PostConstruct
|
@PostConstruct
|
||||||
@Override
|
@Override
|
||||||
public void reload() {
|
public void reload() {
|
||||||
this.removeEssentialsFiles = settings.getProperty(PurgeSettings.REMOVE_ESSENTIALS_FILES);
|
|
||||||
this.removePlayerDat = settings.getProperty(PurgeSettings.REMOVE_PLAYER_DAT);
|
|
||||||
this.removeAntiXrayFiles = settings.getProperty(PurgeSettings.REMOVE_ANTI_XRAY_FILE);
|
|
||||||
this.removeLimitedCreativeInventories = settings.getProperty(PurgeSettings.REMOVE_LIMITED_CREATIVE_INVENTORIES);
|
|
||||||
this.removePermissions = settings.getProperty(PurgeSettings.REMOVE_PERMISSIONS);
|
|
||||||
this.daysBeforePurge = settings.getProperty(PurgeSettings.DAYS_BEFORE_REMOVE_PLAYER);
|
this.daysBeforePurge = settings.getProperty(PurgeSettings.DAYS_BEFORE_REMOVE_PLAYER);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,74 @@
|
|||||||
|
package fr.xephi.authme.command.executable.authme;
|
||||||
|
|
||||||
|
import fr.xephi.authme.task.PurgeService;
|
||||||
|
import fr.xephi.authme.util.BukkitService;
|
||||||
|
import org.bukkit.OfflinePlayer;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.mockito.InjectMocks;
|
||||||
|
import org.mockito.Mock;
|
||||||
|
import org.mockito.runners.MockitoJUnitRunner;
|
||||||
|
|
||||||
|
import java.util.Collections;
|
||||||
|
import java.util.HashSet;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
|
import static com.google.common.collect.Sets.newHashSet;
|
||||||
|
import static org.hamcrest.Matchers.arrayContainingInAnyOrder;
|
||||||
|
import static org.mockito.BDDMockito.given;
|
||||||
|
import static org.mockito.Matchers.argThat;
|
||||||
|
import static org.mockito.Matchers.eq;
|
||||||
|
import static org.mockito.Mockito.mock;
|
||||||
|
import static org.mockito.Mockito.verify;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test for {@link PurgeBannedPlayersCommand}.
|
||||||
|
*/
|
||||||
|
@RunWith(MockitoJUnitRunner.class)
|
||||||
|
public class PurgeBannedPlayersCommandTest {
|
||||||
|
|
||||||
|
@InjectMocks
|
||||||
|
private PurgeBannedPlayersCommand command;
|
||||||
|
|
||||||
|
@Mock
|
||||||
|
private PurgeService purgeService;
|
||||||
|
|
||||||
|
@Mock
|
||||||
|
private BukkitService bukkitService;
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void shouldForwardRequestToService() {
|
||||||
|
// given
|
||||||
|
String[] names = {"bannedPlayer", "other_banned", "evilplayer", "Someone"};
|
||||||
|
OfflinePlayer[] players = offlinePlayersWithNames(names);
|
||||||
|
given(bukkitService.getBannedPlayers()).willReturn(newHashSet(players));
|
||||||
|
CommandSender sender = mock(CommandSender.class);
|
||||||
|
|
||||||
|
// when
|
||||||
|
command.executeCommand(sender, Collections.<String>emptyList());
|
||||||
|
|
||||||
|
// then
|
||||||
|
verify(bukkitService).getBannedPlayers();
|
||||||
|
verify(purgeService).purgePlayers(eq(sender), eq(asLowerCaseSet(names)),
|
||||||
|
argThat(arrayContainingInAnyOrder(players)));
|
||||||
|
}
|
||||||
|
|
||||||
|
private static OfflinePlayer[] offlinePlayersWithNames(String... names) {
|
||||||
|
OfflinePlayer[] players = new OfflinePlayer[names.length];
|
||||||
|
for (int i = 0; i < names.length; ++i) {
|
||||||
|
OfflinePlayer player = mock(OfflinePlayer.class);
|
||||||
|
given(player.getName()).willReturn(names[i]);
|
||||||
|
players[i] = player;
|
||||||
|
}
|
||||||
|
return players;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static Set<String> asLowerCaseSet(String... items) {
|
||||||
|
Set<String> result = new HashSet<>(items.length);
|
||||||
|
for (String item : items) {
|
||||||
|
result.add(item.toLowerCase());
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,89 @@
|
|||||||
|
package fr.xephi.authme.command.executable.authme;
|
||||||
|
|
||||||
|
import fr.xephi.authme.task.PurgeService;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.mockito.ArgumentCaptor;
|
||||||
|
import org.mockito.InjectMocks;
|
||||||
|
import org.mockito.Mock;
|
||||||
|
import org.mockito.runners.MockitoJUnitRunner;
|
||||||
|
|
||||||
|
import java.util.Calendar;
|
||||||
|
import java.util.Collections;
|
||||||
|
|
||||||
|
import static org.hamcrest.Matchers.containsString;
|
||||||
|
import static org.hamcrest.Matchers.greaterThan;
|
||||||
|
import static org.hamcrest.Matchers.not;
|
||||||
|
import static org.junit.Assert.assertThat;
|
||||||
|
import static org.mockito.Matchers.argThat;
|
||||||
|
import static org.mockito.Matchers.eq;
|
||||||
|
import static org.mockito.Mockito.mock;
|
||||||
|
import static org.mockito.Mockito.verify;
|
||||||
|
import static org.mockito.Mockito.verifyZeroInteractions;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test for {@link PurgeCommand}.
|
||||||
|
*/
|
||||||
|
@RunWith(MockitoJUnitRunner.class)
|
||||||
|
public class PurgeCommandTest {
|
||||||
|
|
||||||
|
@InjectMocks
|
||||||
|
private PurgeCommand command;
|
||||||
|
|
||||||
|
@Mock
|
||||||
|
private PurgeService purgeService;
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void shouldHandleInvalidNumber() {
|
||||||
|
// given
|
||||||
|
String interval = "invalid";
|
||||||
|
CommandSender sender = mock(CommandSender.class);
|
||||||
|
|
||||||
|
// when
|
||||||
|
command.executeCommand(sender, Collections.singletonList(interval));
|
||||||
|
|
||||||
|
// then
|
||||||
|
verify(sender).sendMessage(argThat(containsString("The value you've entered is invalid")));
|
||||||
|
verifyZeroInteractions(purgeService);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void shouldRejectTooSmallInterval() {
|
||||||
|
// given
|
||||||
|
String interval = "29";
|
||||||
|
CommandSender sender = mock(CommandSender.class);
|
||||||
|
|
||||||
|
// when
|
||||||
|
command.executeCommand(sender, Collections.singletonList(interval));
|
||||||
|
|
||||||
|
// then
|
||||||
|
verify(sender).sendMessage(argThat(containsString("You can only purge data older than 30 days")));
|
||||||
|
verifyZeroInteractions(purgeService);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void shouldForwardToService() {
|
||||||
|
// given
|
||||||
|
String interval = "45";
|
||||||
|
CommandSender sender = mock(CommandSender.class);
|
||||||
|
|
||||||
|
// when
|
||||||
|
command.executeCommand(sender, Collections.singletonList(interval));
|
||||||
|
|
||||||
|
// then
|
||||||
|
ArgumentCaptor<Long> captor = ArgumentCaptor.forClass(Long.class);
|
||||||
|
verify(purgeService).runPurge(eq(sender), captor.capture());
|
||||||
|
|
||||||
|
// Check the timestamp with a certain tolerance
|
||||||
|
int toleranceMillis = 100;
|
||||||
|
Calendar calendar = Calendar.getInstance();
|
||||||
|
calendar.add(Calendar.DATE, -Integer.valueOf(interval));
|
||||||
|
assertIsCloseTo(captor.getValue(), calendar.getTimeInMillis(), toleranceMillis);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void assertIsCloseTo(long value1, long value2, long tolerance) {
|
||||||
|
assertThat(Math.abs(value1 - value2), not(greaterThan(tolerance)));
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
273
src/test/java/fr/xephi/authme/task/PurgeServiceTest.java
Normal file
273
src/test/java/fr/xephi/authme/task/PurgeServiceTest.java
Normal file
@ -0,0 +1,273 @@
|
|||||||
|
package fr.xephi.authme.task;
|
||||||
|
|
||||||
|
import fr.xephi.authme.ReflectionTestUtils;
|
||||||
|
import fr.xephi.authme.TestHelper;
|
||||||
|
import fr.xephi.authme.datasource.DataSource;
|
||||||
|
import fr.xephi.authme.hooks.PluginHooks;
|
||||||
|
import fr.xephi.authme.initialization.FieldInjection;
|
||||||
|
import fr.xephi.authme.permission.PermissionsManager;
|
||||||
|
import fr.xephi.authme.permission.PlayerStatePermission;
|
||||||
|
import fr.xephi.authme.settings.NewSetting;
|
||||||
|
import fr.xephi.authme.settings.properties.PurgeSettings;
|
||||||
|
import fr.xephi.authme.util.BukkitService;
|
||||||
|
import org.bukkit.OfflinePlayer;
|
||||||
|
import org.bukkit.Server;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.hamcrest.Matchers;
|
||||||
|
import org.junit.Before;
|
||||||
|
import org.junit.BeforeClass;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.mockito.ArgumentCaptor;
|
||||||
|
import org.mockito.Mock;
|
||||||
|
import org.mockito.runners.MockitoJUnitRunner;
|
||||||
|
|
||||||
|
import java.lang.reflect.Field;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Calendar;
|
||||||
|
import java.util.Collections;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.Set;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
import static com.google.common.collect.Sets.newHashSet;
|
||||||
|
import static org.hamcrest.Matchers.containsInAnyOrder;
|
||||||
|
import static org.hamcrest.Matchers.containsString;
|
||||||
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
|
import static org.hamcrest.Matchers.equalToIgnoringCase;
|
||||||
|
import static org.hamcrest.Matchers.greaterThan;
|
||||||
|
import static org.hamcrest.Matchers.not;
|
||||||
|
import static org.junit.Assert.assertThat;
|
||||||
|
import static org.mockito.BDDMockito.given;
|
||||||
|
import static org.mockito.Matchers.anyLong;
|
||||||
|
import static org.mockito.Matchers.anySet;
|
||||||
|
import static org.mockito.Matchers.argThat;
|
||||||
|
import static org.mockito.Matchers.eq;
|
||||||
|
import static org.mockito.Mockito.mock;
|
||||||
|
import static org.mockito.Mockito.never;
|
||||||
|
import static org.mockito.Mockito.verify;
|
||||||
|
import static org.mockito.Mockito.verifyZeroInteractions;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test for {@link PurgeService}.
|
||||||
|
*/
|
||||||
|
@RunWith(MockitoJUnitRunner.class)
|
||||||
|
public class PurgeServiceTest {
|
||||||
|
|
||||||
|
private PurgeService purgeService;
|
||||||
|
|
||||||
|
@Mock
|
||||||
|
private BukkitService bukkitService;
|
||||||
|
@Mock
|
||||||
|
private DataSource dataSource;
|
||||||
|
@Mock
|
||||||
|
private NewSetting settings;
|
||||||
|
@Mock
|
||||||
|
private PermissionsManager permissionsManager;
|
||||||
|
@Mock
|
||||||
|
private PluginHooks pluginHooks;
|
||||||
|
@Mock
|
||||||
|
private Server server;
|
||||||
|
|
||||||
|
@BeforeClass
|
||||||
|
public static void initLogger() {
|
||||||
|
TestHelper.setupLogger();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Before
|
||||||
|
public void initSettingDefaults() {
|
||||||
|
given(settings.getProperty(PurgeSettings.DAYS_BEFORE_REMOVE_PLAYER)).willReturn(60);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void shouldNotRunAutoPurge() {
|
||||||
|
// given
|
||||||
|
given(settings.getProperty(PurgeSettings.USE_AUTO_PURGE)).willReturn(false);
|
||||||
|
|
||||||
|
// when
|
||||||
|
initPurgeService();
|
||||||
|
purgeService.runAutoPurge();
|
||||||
|
|
||||||
|
// then
|
||||||
|
verifyZeroInteractions(bukkitService, dataSource);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void shouldNotRunAutoPurgeForInvalidInterval() {
|
||||||
|
// given
|
||||||
|
given(settings.getProperty(PurgeSettings.USE_AUTO_PURGE)).willReturn(true);
|
||||||
|
given(settings.getProperty(PurgeSettings.DAYS_BEFORE_REMOVE_PLAYER)).willReturn(0);
|
||||||
|
|
||||||
|
// when
|
||||||
|
initPurgeService();
|
||||||
|
purgeService.runAutoPurge();
|
||||||
|
|
||||||
|
// then
|
||||||
|
verifyZeroInteractions(bukkitService, dataSource);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void shouldRunAutoPurge() {
|
||||||
|
// given
|
||||||
|
given(settings.getProperty(PurgeSettings.USE_AUTO_PURGE)).willReturn(true);
|
||||||
|
given(settings.getProperty(PurgeSettings.DAYS_BEFORE_REMOVE_PLAYER)).willReturn(60);
|
||||||
|
String[] playerNames = {"alpha", "bravo", "charlie", "delta"};
|
||||||
|
given(dataSource.getRecordsToPurge(anyLong())).willReturn(newHashSet(playerNames));
|
||||||
|
mockReturnedOfflinePlayers();
|
||||||
|
mockHasBypassPurgePermission("bravo", "delta");
|
||||||
|
|
||||||
|
// when
|
||||||
|
initPurgeService();
|
||||||
|
purgeService.runAutoPurge();
|
||||||
|
|
||||||
|
// then
|
||||||
|
ArgumentCaptor<Long> captor = ArgumentCaptor.forClass(Long.class);
|
||||||
|
verify(dataSource).getRecordsToPurge(captor.capture());
|
||||||
|
assertCorrectPurgeTimestamp(captor.getValue(), 60);
|
||||||
|
verify(dataSource).purgeRecords(newHashSet("alpha", "charlie"));
|
||||||
|
assertThat(purgeService.isPurging(), equalTo(true));
|
||||||
|
verifyScheduledPurgeTask(null, "alpha", "charlie");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void shouldRecognizeNoPlayersToPurge() {
|
||||||
|
// given
|
||||||
|
long delay = 123012301L;
|
||||||
|
given(dataSource.getRecordsToPurge(delay)).willReturn(Collections.<String>emptySet());
|
||||||
|
CommandSender sender = mock(CommandSender.class);
|
||||||
|
|
||||||
|
// when
|
||||||
|
initPurgeService();
|
||||||
|
purgeService.runPurge(sender, delay);
|
||||||
|
|
||||||
|
// then
|
||||||
|
verify(dataSource).getRecordsToPurge(delay);
|
||||||
|
verify(dataSource, never()).purgeRecords(anySet());
|
||||||
|
verify(sender).sendMessage("No players to purge");
|
||||||
|
verifyZeroInteractions(bukkitService, permissionsManager);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void shouldRunPurge() {
|
||||||
|
// given
|
||||||
|
long delay = 1809714L;
|
||||||
|
given(dataSource.getRecordsToPurge(delay)).willReturn(newHashSet("charlie", "delta", "echo", "foxtrot"));
|
||||||
|
mockReturnedOfflinePlayers();
|
||||||
|
mockHasBypassPurgePermission("echo");
|
||||||
|
Player sender = mock(Player.class);
|
||||||
|
UUID uuid = UUID.randomUUID();
|
||||||
|
given(sender.getUniqueId()).willReturn(uuid);
|
||||||
|
|
||||||
|
// when
|
||||||
|
initPurgeService();
|
||||||
|
purgeService.runPurge(sender, delay);
|
||||||
|
|
||||||
|
// then
|
||||||
|
verify(dataSource).getRecordsToPurge(delay);
|
||||||
|
verify(dataSource).purgeRecords(newHashSet("charlie", "delta", "foxtrot"));
|
||||||
|
verify(sender).sendMessage(argThat(containsString("Deleted 3 user accounts")));
|
||||||
|
verifyScheduledPurgeTask(uuid, "charlie", "delta", "foxtrot");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void shouldRunPurgeIfProcessIsAlreadyRunning() {
|
||||||
|
// given
|
||||||
|
initPurgeService();
|
||||||
|
purgeService.setPurging(true);
|
||||||
|
CommandSender sender = mock(CommandSender.class);
|
||||||
|
OfflinePlayer[] players = mockReturnedOfflinePlayers();
|
||||||
|
|
||||||
|
// when
|
||||||
|
purgeService.purgePlayers(sender, newHashSet("test", "names"), players);
|
||||||
|
|
||||||
|
// then
|
||||||
|
verify(sender).sendMessage(argThat(containsString("Purge is already in progress")));
|
||||||
|
verifyZeroInteractions(bukkitService, dataSource, permissionsManager);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns mock OfflinePlayer objects with names corresponding to A - G of the NATO phonetic alphabet,
|
||||||
|
* in various casing.
|
||||||
|
*
|
||||||
|
* @return list of offline players BukkitService is mocked to return
|
||||||
|
*/
|
||||||
|
private OfflinePlayer[] mockReturnedOfflinePlayers() {
|
||||||
|
String[] names = { "alfa", "Bravo", "charLIE", "delta", "ECHO", "Foxtrot", "golf" };
|
||||||
|
OfflinePlayer[] players = new OfflinePlayer[names.length];
|
||||||
|
for (int i = 0; i < names.length; ++i) {
|
||||||
|
OfflinePlayer player = mock(OfflinePlayer.class);
|
||||||
|
given(player.getName()).willReturn(names[i]);
|
||||||
|
players[i] = player;
|
||||||
|
}
|
||||||
|
given(bukkitService.getOfflinePlayers()).willReturn(players);
|
||||||
|
return players;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Mocks the permission manager to say that the given names have the bypass purge permission.
|
||||||
|
*
|
||||||
|
* @param names the names
|
||||||
|
*/
|
||||||
|
private void mockHasBypassPurgePermission(String... names) {
|
||||||
|
for (String name : names) {
|
||||||
|
given(permissionsManager.hasPermissionOffline(
|
||||||
|
argThat(equalToIgnoringCase(name)), eq(PlayerStatePermission.BYPASS_PURGE))).willReturn(true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void assertCorrectPurgeTimestamp(long timestamp, int configuredDays) {
|
||||||
|
final long toleranceMillis = 100L;
|
||||||
|
Calendar cal = Calendar.getInstance();
|
||||||
|
cal.add(Calendar.DATE, -configuredDays);
|
||||||
|
long expectedTimestamp = cal.getTimeInMillis();
|
||||||
|
|
||||||
|
assertThat("Timestamp is equal to now minus " + configuredDays + " days (within tolerance)",
|
||||||
|
Math.abs(timestamp - expectedTimestamp), not(greaterThan(toleranceMillis)));
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("unchecked")
|
||||||
|
private void verifyScheduledPurgeTask(UUID uuid, String... names) {
|
||||||
|
ArgumentCaptor<PurgeTask> captor = ArgumentCaptor.forClass(PurgeTask.class);
|
||||||
|
verify(bukkitService).runTaskAsynchronously(captor.capture());
|
||||||
|
PurgeTask task = captor.getValue();
|
||||||
|
|
||||||
|
Object senderInTask = ReflectionTestUtils.getFieldValue(PurgeTask.class, task, "sender");
|
||||||
|
Set<String> namesInTask = (Set<String>) ReflectionTestUtils.getFieldValue(PurgeTask.class, task, "toPurge");
|
||||||
|
assertThat(senderInTask, Matchers.<Object>equalTo(uuid));
|
||||||
|
assertThat(namesInTask, containsInAnyOrder(names));
|
||||||
|
}
|
||||||
|
|
||||||
|
// ---------------
|
||||||
|
// TODO ljacqu 20160618: Create a delayed injection test runner instead
|
||||||
|
private void initPurgeService() {
|
||||||
|
FieldInjection<PurgeService> injection = FieldInjection.provide(PurgeService.class).get();
|
||||||
|
purgeService = injection.instantiateWith(getFields(injection.getDependencies()));
|
||||||
|
purgeService.reload(); // because annotated with @PostConstruct
|
||||||
|
}
|
||||||
|
|
||||||
|
private Object[] getFields(Class<?>[] classes) {
|
||||||
|
Map<Class<?>, Object> mocksByType = orderMocksByType();
|
||||||
|
List<Object> orderedMocks = new ArrayList<>(classes.length);
|
||||||
|
for (Class<?> clazz : classes) {
|
||||||
|
orderedMocks.add(mocksByType.get(clazz));
|
||||||
|
}
|
||||||
|
return orderedMocks.toArray();
|
||||||
|
}
|
||||||
|
|
||||||
|
private Map<Class<?>, Object> orderMocksByType() {
|
||||||
|
Map<Class<?>, Object> mocksByType = new HashMap<>();
|
||||||
|
for (Field field : PurgeServiceTest.class.getDeclaredFields()) {
|
||||||
|
if (field.isAnnotationPresent(Mock.class)) {
|
||||||
|
try {
|
||||||
|
mocksByType.put(field.getType(), field.get(this));
|
||||||
|
} catch (IllegalAccessException e) {
|
||||||
|
throw new IllegalStateException(e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return mocksByType;
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user