mirror of
https://github.com/AuthMe/AuthMeReloaded.git
synced 2025-01-21 15:11:35 +01:00
#1413 Don't run onUnregister command in async
This commit is contained in:
parent
f6423f5072
commit
4717dc148c
@ -120,7 +120,8 @@ public class AsynchronousUnregister implements AsynchronousProcess {
|
|||||||
if (player == null || !player.isOnline()) {
|
if (player == null || !player.isOnline()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
commandManager.runCommandsOnUnregister(player);
|
bukkitService.scheduleSyncTaskFromOptionallyAsyncTask(() ->
|
||||||
|
commandManager.runCommandsOnUnregister(player));
|
||||||
|
|
||||||
if (service.getProperty(RegistrationSettings.FORCE)) {
|
if (service.getProperty(RegistrationSettings.FORCE)) {
|
||||||
teleportationService.teleportOnJoin(player);
|
teleportationService.teleportOnJoin(player);
|
||||||
|
@ -23,6 +23,7 @@ import java.util.logging.Logger;
|
|||||||
import static org.mockito.ArgumentMatchers.any;
|
import static org.mockito.ArgumentMatchers.any;
|
||||||
import static org.mockito.ArgumentMatchers.anyLong;
|
import static org.mockito.ArgumentMatchers.anyLong;
|
||||||
import static org.mockito.BDDMockito.given;
|
import static org.mockito.BDDMockito.given;
|
||||||
|
import static org.mockito.Mockito.doAnswer;
|
||||||
import static org.mockito.Mockito.mock;
|
import static org.mockito.Mockito.mock;
|
||||||
import static org.mockito.Mockito.verify;
|
import static org.mockito.Mockito.verify;
|
||||||
|
|
||||||
@ -134,17 +135,17 @@ public final class TestHelper {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Execute a {@link Runnable} passed to a mock's {@link BukkitService#scheduleSyncTaskFromOptionallyAsyncTask}
|
* Sets a BukkitService mock to run any Runnable it is passed to its method
|
||||||
* method. Note that calling this method expects that there be a runnable sent to the method and will fail
|
* {@link BukkitService#scheduleSyncTaskFromOptionallyAsyncTask}.
|
||||||
* otherwise.
|
|
||||||
*
|
*
|
||||||
* @param service The mock service
|
* @param bukkitService the mock to set behavior on
|
||||||
*/
|
*/
|
||||||
public static void runSyncTaskFromOptionallyAsyncTask(BukkitService service) {
|
public static void setBukkitServiceToRunOptionallyAsyncTasks(BukkitService bukkitService) {
|
||||||
ArgumentCaptor<Runnable> captor = ArgumentCaptor.forClass(Runnable.class);
|
doAnswer(invocation -> {
|
||||||
verify(service).scheduleSyncTaskFromOptionallyAsyncTask(captor.capture());
|
Runnable runnable = invocation.getArgument(0);
|
||||||
Runnable runnable = captor.getValue();
|
|
||||||
runnable.run();
|
runnable.run();
|
||||||
|
return null;
|
||||||
|
}).when(bukkitService).scheduleSyncTaskFromOptionallyAsyncTask(any(Runnable.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -22,7 +22,7 @@ import org.mockito.junit.MockitoJUnitRunner;
|
|||||||
|
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
|
|
||||||
import static fr.xephi.authme.TestHelper.runSyncTaskFromOptionallyAsyncTask;
|
import static fr.xephi.authme.TestHelper.setBukkitServiceToRunOptionallyAsyncTasks;
|
||||||
import static org.hamcrest.Matchers.equalTo;
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
import static org.junit.Assert.assertThat;
|
import static org.junit.Assert.assertThat;
|
||||||
import static org.mockito.ArgumentMatchers.any;
|
import static org.mockito.ArgumentMatchers.any;
|
||||||
@ -161,11 +161,11 @@ public class RegisterAdminCommandTest {
|
|||||||
String kickForAdminRegister = "Admin registered you -- log in again";
|
String kickForAdminRegister = "Admin registered you -- log in again";
|
||||||
given(commandService.retrieveSingleMessage(MessageKey.KICK_FOR_ADMIN_REGISTER)).willReturn(kickForAdminRegister);
|
given(commandService.retrieveSingleMessage(MessageKey.KICK_FOR_ADMIN_REGISTER)).willReturn(kickForAdminRegister);
|
||||||
CommandSender sender = mock(CommandSender.class);
|
CommandSender sender = mock(CommandSender.class);
|
||||||
|
setBukkitServiceToRunOptionallyAsyncTasks(bukkitService);
|
||||||
|
|
||||||
// when
|
// when
|
||||||
command.executeCommand(sender, Arrays.asList(user, password));
|
command.executeCommand(sender, Arrays.asList(user, password));
|
||||||
TestHelper.runOptionallyAsyncTask(bukkitService);
|
TestHelper.runOptionallyAsyncTask(bukkitService);
|
||||||
runSyncTaskFromOptionallyAsyncTask(bukkitService);
|
|
||||||
|
|
||||||
// then
|
// then
|
||||||
verify(validationService).validatePassword(password, user);
|
verify(validationService).validatePassword(password, user);
|
||||||
|
@ -13,10 +13,14 @@ import fr.xephi.authme.service.BukkitService;
|
|||||||
import fr.xephi.authme.service.CommonService;
|
import fr.xephi.authme.service.CommonService;
|
||||||
import fr.xephi.authme.service.TeleportationService;
|
import fr.xephi.authme.service.TeleportationService;
|
||||||
import fr.xephi.authme.service.bungeecord.BungeeSender;
|
import fr.xephi.authme.service.bungeecord.BungeeSender;
|
||||||
|
import fr.xephi.authme.service.bungeecord.MessageType;
|
||||||
import fr.xephi.authme.settings.commandconfig.CommandManager;
|
import fr.xephi.authme.settings.commandconfig.CommandManager;
|
||||||
import fr.xephi.authme.settings.properties.RegistrationSettings;
|
import fr.xephi.authme.settings.properties.RegistrationSettings;
|
||||||
|
import fr.xephi.authme.settings.properties.RestrictionSettings;
|
||||||
import org.bukkit.command.CommandSender;
|
import org.bukkit.command.CommandSender;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.potion.PotionEffect;
|
||||||
|
import org.bukkit.potion.PotionEffectType;
|
||||||
import org.junit.BeforeClass;
|
import org.junit.BeforeClass;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
@ -27,6 +31,7 @@ import org.mockito.junit.MockitoJUnitRunner;
|
|||||||
|
|
||||||
import java.util.function.Function;
|
import java.util.function.Function;
|
||||||
|
|
||||||
|
import static fr.xephi.authme.TestHelper.setBukkitServiceToRunOptionallyAsyncTasks;
|
||||||
import static org.hamcrest.Matchers.equalTo;
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
import static org.junit.Assert.assertThat;
|
import static org.junit.Assert.assertThat;
|
||||||
import static org.mockito.ArgumentMatchers.any;
|
import static org.mockito.ArgumentMatchers.any;
|
||||||
@ -89,7 +94,7 @@ public class AsynchronousUnregisterTest {
|
|||||||
// then
|
// then
|
||||||
verify(service).send(player, MessageKey.WRONG_PASSWORD);
|
verify(service).send(player, MessageKey.WRONG_PASSWORD);
|
||||||
verify(passwordSecurity).comparePassword(userPassword, password, name);
|
verify(passwordSecurity).comparePassword(userPassword, password, name);
|
||||||
verifyZeroInteractions(dataSource, limboService, teleportationService, bukkitService);
|
verifyZeroInteractions(dataSource, limboService, teleportationService, bukkitService, bungeeSender);
|
||||||
verify(player, only()).getName();
|
verify(player, only()).getName();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -108,6 +113,9 @@ public class AsynchronousUnregisterTest {
|
|||||||
given(passwordSecurity.comparePassword(userPassword, password, name)).willReturn(true);
|
given(passwordSecurity.comparePassword(userPassword, password, name)).willReturn(true);
|
||||||
given(dataSource.removeAuth(name)).willReturn(true);
|
given(dataSource.removeAuth(name)).willReturn(true);
|
||||||
given(service.getProperty(RegistrationSettings.FORCE)).willReturn(true);
|
given(service.getProperty(RegistrationSettings.FORCE)).willReturn(true);
|
||||||
|
given(service.getProperty(RegistrationSettings.APPLY_BLIND_EFFECT)).willReturn(true);
|
||||||
|
given(service.getProperty(RestrictionSettings.TIMEOUT)).willReturn(21);
|
||||||
|
setBukkitServiceToRunOptionallyAsyncTasks(bukkitService);
|
||||||
|
|
||||||
// when
|
// when
|
||||||
asynchronousUnregister.unregister(player, userPassword);
|
asynchronousUnregister.unregister(player, userPassword);
|
||||||
@ -118,9 +126,10 @@ public class AsynchronousUnregisterTest {
|
|||||||
verify(dataSource).removeAuth(name);
|
verify(dataSource).removeAuth(name);
|
||||||
verify(playerCache).removePlayer(name);
|
verify(playerCache).removePlayer(name);
|
||||||
verify(teleportationService).teleportOnJoin(player);
|
verify(teleportationService).teleportOnJoin(player);
|
||||||
verify(bukkitService).scheduleSyncTaskFromOptionallyAsyncTask(any(Runnable.class));
|
|
||||||
verifyCalledUnregisterEventFor(player);
|
verifyCalledUnregisterEventFor(player);
|
||||||
verify(commandManager).runCommandsOnUnregister(player);
|
verify(commandManager).runCommandsOnUnregister(player);
|
||||||
|
verify(bungeeSender).sendAuthMeBungeecordMessage(MessageType.UNREGISTER, name);
|
||||||
|
verify(player).addPotionEffect(new PotionEffect(PotionEffectType.BLINDNESS, 21 * 20, 2));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@ -138,6 +147,8 @@ public class AsynchronousUnregisterTest {
|
|||||||
given(passwordSecurity.comparePassword(userPassword, password, name)).willReturn(true);
|
given(passwordSecurity.comparePassword(userPassword, password, name)).willReturn(true);
|
||||||
given(dataSource.removeAuth(name)).willReturn(true);
|
given(dataSource.removeAuth(name)).willReturn(true);
|
||||||
given(service.getProperty(RegistrationSettings.FORCE)).willReturn(true);
|
given(service.getProperty(RegistrationSettings.FORCE)).willReturn(true);
|
||||||
|
given(service.getProperty(RegistrationSettings.APPLY_BLIND_EFFECT)).willReturn(false);
|
||||||
|
setBukkitServiceToRunOptionallyAsyncTasks(bukkitService);
|
||||||
|
|
||||||
// when
|
// when
|
||||||
asynchronousUnregister.unregister(player, userPassword);
|
asynchronousUnregister.unregister(player, userPassword);
|
||||||
@ -148,9 +159,10 @@ public class AsynchronousUnregisterTest {
|
|||||||
verify(dataSource).removeAuth(name);
|
verify(dataSource).removeAuth(name);
|
||||||
verify(playerCache).removePlayer(name);
|
verify(playerCache).removePlayer(name);
|
||||||
verify(teleportationService).teleportOnJoin(player);
|
verify(teleportationService).teleportOnJoin(player);
|
||||||
verify(bukkitService).scheduleSyncTaskFromOptionallyAsyncTask(any(Runnable.class));
|
|
||||||
verifyCalledUnregisterEventFor(player);
|
verifyCalledUnregisterEventFor(player);
|
||||||
verify(commandManager).runCommandsOnUnregister(player);
|
verify(commandManager).runCommandsOnUnregister(player);
|
||||||
|
verify(bungeeSender).sendAuthMeBungeecordMessage(MessageType.UNREGISTER, name);
|
||||||
|
verify(player, never()).addPotionEffect(any(PotionEffect.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@ -167,6 +179,7 @@ public class AsynchronousUnregisterTest {
|
|||||||
given(passwordSecurity.comparePassword(userPassword, password, name)).willReturn(true);
|
given(passwordSecurity.comparePassword(userPassword, password, name)).willReturn(true);
|
||||||
given(dataSource.removeAuth(name)).willReturn(true);
|
given(dataSource.removeAuth(name)).willReturn(true);
|
||||||
given(service.getProperty(RegistrationSettings.FORCE)).willReturn(false);
|
given(service.getProperty(RegistrationSettings.FORCE)).willReturn(false);
|
||||||
|
setBukkitServiceToRunOptionallyAsyncTasks(bukkitService);
|
||||||
|
|
||||||
// when
|
// when
|
||||||
asynchronousUnregister.unregister(player, userPassword);
|
asynchronousUnregister.unregister(player, userPassword);
|
||||||
@ -177,8 +190,8 @@ public class AsynchronousUnregisterTest {
|
|||||||
verify(dataSource).removeAuth(name);
|
verify(dataSource).removeAuth(name);
|
||||||
verify(playerCache).removePlayer(name);
|
verify(playerCache).removePlayer(name);
|
||||||
verifyZeroInteractions(teleportationService, limboService);
|
verifyZeroInteractions(teleportationService, limboService);
|
||||||
verify(bukkitService, never()).runTask(any(Runnable.class));
|
|
||||||
verifyCalledUnregisterEventFor(player);
|
verifyCalledUnregisterEventFor(player);
|
||||||
|
verify(bungeeSender).sendAuthMeBungeecordMessage(MessageType.UNREGISTER, name);
|
||||||
verify(commandManager).runCommandsOnUnregister(player);
|
verify(commandManager).runCommandsOnUnregister(player);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -203,7 +216,7 @@ public class AsynchronousUnregisterTest {
|
|||||||
verify(passwordSecurity).comparePassword(userPassword, password, name);
|
verify(passwordSecurity).comparePassword(userPassword, password, name);
|
||||||
verify(dataSource).removeAuth(name);
|
verify(dataSource).removeAuth(name);
|
||||||
verify(service).send(player, MessageKey.ERROR);
|
verify(service).send(player, MessageKey.ERROR);
|
||||||
verifyZeroInteractions(teleportationService, bukkitService);
|
verifyZeroInteractions(teleportationService, bukkitService, bungeeSender);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@ -230,6 +243,7 @@ public class AsynchronousUnregisterTest {
|
|||||||
verify(playerCache).removePlayer(name);
|
verify(playerCache).removePlayer(name);
|
||||||
verifyZeroInteractions(teleportationService);
|
verifyZeroInteractions(teleportationService);
|
||||||
verifyCalledUnregisterEventFor(player);
|
verifyCalledUnregisterEventFor(player);
|
||||||
|
verify(bungeeSender).sendAuthMeBungeecordMessage(MessageType.UNREGISTER, name);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Initiator known and Player object available
|
// Initiator known and Player object available
|
||||||
@ -241,7 +255,9 @@ public class AsynchronousUnregisterTest {
|
|||||||
given(player.isOnline()).willReturn(true);
|
given(player.isOnline()).willReturn(true);
|
||||||
given(dataSource.removeAuth(name)).willReturn(true);
|
given(dataSource.removeAuth(name)).willReturn(true);
|
||||||
given(service.getProperty(RegistrationSettings.FORCE)).willReturn(true);
|
given(service.getProperty(RegistrationSettings.FORCE)).willReturn(true);
|
||||||
|
given(service.getProperty(RegistrationSettings.APPLY_BLIND_EFFECT)).willReturn(false);
|
||||||
CommandSender initiator = mock(CommandSender.class);
|
CommandSender initiator = mock(CommandSender.class);
|
||||||
|
setBukkitServiceToRunOptionallyAsyncTasks(bukkitService);
|
||||||
|
|
||||||
// when
|
// when
|
||||||
asynchronousUnregister.adminUnregister(initiator, name, player);
|
asynchronousUnregister.adminUnregister(initiator, name, player);
|
||||||
@ -252,9 +268,9 @@ public class AsynchronousUnregisterTest {
|
|||||||
verify(dataSource).removeAuth(name);
|
verify(dataSource).removeAuth(name);
|
||||||
verify(playerCache).removePlayer(name);
|
verify(playerCache).removePlayer(name);
|
||||||
verify(teleportationService).teleportOnJoin(player);
|
verify(teleportationService).teleportOnJoin(player);
|
||||||
verify(bukkitService).scheduleSyncTaskFromOptionallyAsyncTask(any(Runnable.class));
|
|
||||||
verifyCalledUnregisterEventFor(player);
|
verifyCalledUnregisterEventFor(player);
|
||||||
verify(commandManager).runCommandsOnUnregister(player);
|
verify(commandManager).runCommandsOnUnregister(player);
|
||||||
|
verify(bungeeSender).sendAuthMeBungeecordMessage(MessageType.UNREGISTER, name);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@ -271,6 +287,7 @@ public class AsynchronousUnregisterTest {
|
|||||||
verify(playerCache).removePlayer(name);
|
verify(playerCache).removePlayer(name);
|
||||||
verifyZeroInteractions(teleportationService);
|
verifyZeroInteractions(teleportationService);
|
||||||
verifyCalledUnregisterEventFor(null);
|
verifyCalledUnregisterEventFor(null);
|
||||||
|
verify(bungeeSender).sendAuthMeBungeecordMessage(MessageType.UNREGISTER, name);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@ -286,7 +303,7 @@ public class AsynchronousUnregisterTest {
|
|||||||
// then
|
// then
|
||||||
verify(dataSource).removeAuth(name);
|
verify(dataSource).removeAuth(name);
|
||||||
verify(service).send(initiator, MessageKey.ERROR);
|
verify(service).send(initiator, MessageKey.ERROR);
|
||||||
verifyZeroInteractions(playerCache, teleportationService, bukkitService);
|
verifyZeroInteractions(playerCache, teleportationService, bukkitService, bungeeSender);
|
||||||
}
|
}
|
||||||
|
|
||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
|
@ -17,14 +17,11 @@ import org.junit.runner.RunWith;
|
|||||||
import org.mockito.ArgumentCaptor;
|
import org.mockito.ArgumentCaptor;
|
||||||
import org.mockito.InjectMocks;
|
import org.mockito.InjectMocks;
|
||||||
import org.mockito.Mock;
|
import org.mockito.Mock;
|
||||||
import org.mockito.invocation.InvocationOnMock;
|
|
||||||
import org.mockito.junit.MockitoJUnitRunner;
|
import org.mockito.junit.MockitoJUnitRunner;
|
||||||
import org.mockito.stubbing.Answer;
|
|
||||||
|
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
|
|
||||||
import static fr.xephi.authme.TestHelper.runSyncDelayedTask;
|
import static fr.xephi.authme.TestHelper.setBukkitServiceToRunOptionallyAsyncTasks;
|
||||||
import static fr.xephi.authme.TestHelper.runSyncTaskFromOptionallyAsyncTask;
|
|
||||||
import static org.hamcrest.Matchers.equalTo;
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
import static org.junit.Assert.assertThat;
|
import static org.junit.Assert.assertThat;
|
||||||
import static org.mockito.ArgumentMatchers.any;
|
import static org.mockito.ArgumentMatchers.any;
|
||||||
@ -92,10 +89,10 @@ public class TeleportationServiceTest {
|
|||||||
given(player.isOnline()).willReturn(true);
|
given(player.isOnline()).willReturn(true);
|
||||||
Location firstSpawn = mockLocation();
|
Location firstSpawn = mockLocation();
|
||||||
given(spawnLoader.getFirstSpawn()).willReturn(firstSpawn);
|
given(spawnLoader.getFirstSpawn()).willReturn(firstSpawn);
|
||||||
|
setBukkitServiceToRunOptionallyAsyncTasks(bukkitService);
|
||||||
|
|
||||||
// when
|
// when
|
||||||
teleportationService.teleportNewPlayerToFirstSpawn(player);
|
teleportationService.teleportNewPlayerToFirstSpawn(player);
|
||||||
runSyncTaskFromOptionallyAsyncTask(bukkitService);
|
|
||||||
|
|
||||||
// then
|
// then
|
||||||
verify(player).teleport(firstSpawn);
|
verify(player).teleport(firstSpawn);
|
||||||
@ -112,10 +109,10 @@ public class TeleportationServiceTest {
|
|||||||
given(player.isOnline()).willReturn(true);
|
given(player.isOnline()).willReturn(true);
|
||||||
Location spawn = mockLocation();
|
Location spawn = mockLocation();
|
||||||
given(spawnLoader.getSpawnLocation(player)).willReturn(spawn);
|
given(spawnLoader.getSpawnLocation(player)).willReturn(spawn);
|
||||||
|
setBukkitServiceToRunOptionallyAsyncTasks(bukkitService);
|
||||||
|
|
||||||
// when
|
// when
|
||||||
teleportationService.teleportOnJoin(player);
|
teleportationService.teleportOnJoin(player);
|
||||||
runSyncTaskFromOptionallyAsyncTask(bukkitService);
|
|
||||||
|
|
||||||
// then
|
// then
|
||||||
verify(player).teleport(spawn);
|
verify(player).teleport(spawn);
|
||||||
@ -175,19 +172,16 @@ public class TeleportationServiceTest {
|
|||||||
Location spawn = mockLocation();
|
Location spawn = mockLocation();
|
||||||
given(spawnLoader.getSpawnLocation(player)).willReturn(spawn);
|
given(spawnLoader.getSpawnLocation(player)).willReturn(spawn);
|
||||||
given(settings.getProperty(RestrictionSettings.TELEPORT_UNAUTHED_TO_SPAWN)).willReturn(true);
|
given(settings.getProperty(RestrictionSettings.TELEPORT_UNAUTHED_TO_SPAWN)).willReturn(true);
|
||||||
doAnswer(new Answer<Void>() {
|
doAnswer(invocation -> {
|
||||||
@Override
|
|
||||||
public Void answer(InvocationOnMock invocation) throws Throwable {
|
|
||||||
SpawnTeleportEvent event = (SpawnTeleportEvent) invocation.getArguments()[0];
|
SpawnTeleportEvent event = (SpawnTeleportEvent) invocation.getArguments()[0];
|
||||||
assertThat(event.getPlayer(), equalTo(player));
|
assertThat(event.getPlayer(), equalTo(player));
|
||||||
event.setTo(null);
|
event.setTo(null);
|
||||||
return null;
|
return null;
|
||||||
}
|
|
||||||
}).when(bukkitService).callEvent(any(SpawnTeleportEvent.class));
|
}).when(bukkitService).callEvent(any(SpawnTeleportEvent.class));
|
||||||
|
setBukkitServiceToRunOptionallyAsyncTasks(bukkitService);
|
||||||
|
|
||||||
// when
|
// when
|
||||||
teleportationService.teleportOnJoin(player);
|
teleportationService.teleportOnJoin(player);
|
||||||
runSyncTaskFromOptionallyAsyncTask(bukkitService);
|
|
||||||
|
|
||||||
// then
|
// then
|
||||||
verify(bukkitService).callEvent(any(SpawnTeleportEvent.class));
|
verify(bukkitService).callEvent(any(SpawnTeleportEvent.class));
|
||||||
@ -201,19 +195,16 @@ public class TeleportationServiceTest {
|
|||||||
Location spawn = mockLocation();
|
Location spawn = mockLocation();
|
||||||
given(spawnLoader.getSpawnLocation(player)).willReturn(spawn);
|
given(spawnLoader.getSpawnLocation(player)).willReturn(spawn);
|
||||||
given(settings.getProperty(RestrictionSettings.TELEPORT_UNAUTHED_TO_SPAWN)).willReturn(true);
|
given(settings.getProperty(RestrictionSettings.TELEPORT_UNAUTHED_TO_SPAWN)).willReturn(true);
|
||||||
doAnswer(new Answer<Void>() {
|
doAnswer(invocation -> {
|
||||||
@Override
|
|
||||||
public Void answer(InvocationOnMock invocation) throws Throwable {
|
|
||||||
SpawnTeleportEvent event = (SpawnTeleportEvent) invocation.getArguments()[0];
|
SpawnTeleportEvent event = (SpawnTeleportEvent) invocation.getArguments()[0];
|
||||||
assertThat(event.getPlayer(), equalTo(player));
|
assertThat(event.getPlayer(), equalTo(player));
|
||||||
event.setCancelled(true);
|
event.setCancelled(true);
|
||||||
return null;
|
return null;
|
||||||
}
|
|
||||||
}).when(bukkitService).callEvent(any(SpawnTeleportEvent.class));
|
}).when(bukkitService).callEvent(any(SpawnTeleportEvent.class));
|
||||||
|
setBukkitServiceToRunOptionallyAsyncTasks(bukkitService);
|
||||||
|
|
||||||
// when
|
// when
|
||||||
teleportationService.teleportOnJoin(player);
|
teleportationService.teleportOnJoin(player);
|
||||||
runSyncTaskFromOptionallyAsyncTask(bukkitService);
|
|
||||||
|
|
||||||
// then
|
// then
|
||||||
verify(bukkitService).callEvent(any(SpawnTeleportEvent.class));
|
verify(bukkitService).callEvent(any(SpawnTeleportEvent.class));
|
||||||
@ -251,10 +242,10 @@ public class TeleportationServiceTest {
|
|||||||
Location limboLocation = mockLocation();
|
Location limboLocation = mockLocation();
|
||||||
given(limboLocation.getWorld().getName()).willReturn("forced1");
|
given(limboLocation.getWorld().getName()).willReturn("forced1");
|
||||||
given(limbo.getLocation()).willReturn(limboLocation);
|
given(limbo.getLocation()).willReturn(limboLocation);
|
||||||
|
setBukkitServiceToRunOptionallyAsyncTasks(bukkitService);
|
||||||
|
|
||||||
// when
|
// when
|
||||||
teleportationService.teleportOnLogin(player, auth, limbo);
|
teleportationService.teleportOnLogin(player, auth, limbo);
|
||||||
runSyncTaskFromOptionallyAsyncTask(bukkitService);
|
|
||||||
|
|
||||||
// then
|
// then
|
||||||
verify(player).teleport(spawn);
|
verify(player).teleport(spawn);
|
||||||
@ -298,10 +289,10 @@ public class TeleportationServiceTest {
|
|||||||
LimboPlayer limbo = mock(LimboPlayer.class);
|
LimboPlayer limbo = mock(LimboPlayer.class);
|
||||||
Location limboLocation = mockLocation();
|
Location limboLocation = mockLocation();
|
||||||
given(limbo.getLocation()).willReturn(limboLocation);
|
given(limbo.getLocation()).willReturn(limboLocation);
|
||||||
|
setBukkitServiceToRunOptionallyAsyncTasks(bukkitService);
|
||||||
|
|
||||||
// when
|
// when
|
||||||
teleportationService.teleportOnLogin(player, auth, limbo);
|
teleportationService.teleportOnLogin(player, auth, limbo);
|
||||||
runSyncTaskFromOptionallyAsyncTask(bukkitService);
|
|
||||||
|
|
||||||
// then
|
// then
|
||||||
ArgumentCaptor<Location> locationCaptor = ArgumentCaptor.forClass(Location.class);
|
ArgumentCaptor<Location> locationCaptor = ArgumentCaptor.forClass(Location.class);
|
||||||
@ -326,10 +317,10 @@ public class TeleportationServiceTest {
|
|||||||
LimboPlayer limbo = mock(LimboPlayer.class);
|
LimboPlayer limbo = mock(LimboPlayer.class);
|
||||||
Location limboLocation = mockLocation();
|
Location limboLocation = mockLocation();
|
||||||
given(limbo.getLocation()).willReturn(limboLocation);
|
given(limbo.getLocation()).willReturn(limboLocation);
|
||||||
|
setBukkitServiceToRunOptionallyAsyncTasks(bukkitService);
|
||||||
|
|
||||||
// when
|
// when
|
||||||
teleportationService.teleportOnLogin(player, auth, limbo);
|
teleportationService.teleportOnLogin(player, auth, limbo);
|
||||||
runSyncTaskFromOptionallyAsyncTask(bukkitService);
|
|
||||||
|
|
||||||
// then
|
// then
|
||||||
ArgumentCaptor<Location> locationCaptor = ArgumentCaptor.forClass(Location.class);
|
ArgumentCaptor<Location> locationCaptor = ArgumentCaptor.forClass(Location.class);
|
||||||
@ -351,10 +342,10 @@ public class TeleportationServiceTest {
|
|||||||
LimboPlayer limbo = mock(LimboPlayer.class);
|
LimboPlayer limbo = mock(LimboPlayer.class);
|
||||||
Location location = mockLocation();
|
Location location = mockLocation();
|
||||||
given(limbo.getLocation()).willReturn(location);
|
given(limbo.getLocation()).willReturn(location);
|
||||||
|
setBukkitServiceToRunOptionallyAsyncTasks(bukkitService);
|
||||||
|
|
||||||
// when
|
// when
|
||||||
teleportationService.teleportOnLogin(player, auth, limbo);
|
teleportationService.teleportOnLogin(player, auth, limbo);
|
||||||
runSyncTaskFromOptionallyAsyncTask(bukkitService);
|
|
||||||
|
|
||||||
// then
|
// then
|
||||||
verify(player).teleport(location);
|
verify(player).teleport(location);
|
||||||
@ -373,10 +364,10 @@ public class TeleportationServiceTest {
|
|||||||
LimboPlayer limbo = mock(LimboPlayer.class);
|
LimboPlayer limbo = mock(LimboPlayer.class);
|
||||||
Location location = mockLocation();
|
Location location = mockLocation();
|
||||||
given(limbo.getLocation()).willReturn(location);
|
given(limbo.getLocation()).willReturn(location);
|
||||||
|
setBukkitServiceToRunOptionallyAsyncTasks(bukkitService);
|
||||||
|
|
||||||
// when
|
// when
|
||||||
teleportationService.teleportOnLogin(player, auth, limbo);
|
teleportationService.teleportOnLogin(player, auth, limbo);
|
||||||
runSyncTaskFromOptionallyAsyncTask(bukkitService);
|
|
||||||
|
|
||||||
// then
|
// then
|
||||||
verify(player).teleport(location);
|
verify(player).teleport(location);
|
||||||
|
Loading…
Reference in New Issue
Block a user