mirror of
https://github.com/BentoBoxWorld/BentoBox.git
synced 2025-01-09 18:08:27 +01:00
commit
a1c552b006
@ -129,6 +129,7 @@ public abstract class AbstractCommonSetup {
|
|||||||
when(location.getBlockY()).thenReturn(0);
|
when(location.getBlockY()).thenReturn(0);
|
||||||
when(location.getBlockZ()).thenReturn(0);
|
when(location.getBlockZ()).thenReturn(0);
|
||||||
when(location.toVector()).thenReturn(new Vector(0,0,0));
|
when(location.toVector()).thenReturn(new Vector(0,0,0));
|
||||||
|
when(location.clone()).thenReturn(location); // Paper
|
||||||
|
|
||||||
// Players Manager and meta data
|
// Players Manager and meta data
|
||||||
PlayersManager pm = mock(PlayersManager.class);
|
PlayersManager pm = mock(PlayersManager.class);
|
||||||
|
@ -55,7 +55,6 @@ import world.bentobox.bentobox.util.Util;
|
|||||||
* @author tastybento
|
* @author tastybento
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
@Ignore("Needs update to work with PaperAPI")
|
|
||||||
@RunWith(PowerMockRunner.class)
|
@RunWith(PowerMockRunner.class)
|
||||||
@PrepareForTest({ Bukkit.class, BentoBox.class, User.class, Util.class , ServerBuildInfo.class})
|
@PrepareForTest({ Bukkit.class, BentoBox.class, User.class, Util.class , ServerBuildInfo.class})
|
||||||
public class IslandTeamInviteCommandTest extends RanksManagerBeforeClassTest {
|
public class IslandTeamInviteCommandTest extends RanksManagerBeforeClassTest {
|
||||||
@ -227,6 +226,7 @@ public class IslandTeamInviteCommandTest extends RanksManagerBeforeClassTest {
|
|||||||
* Test method for
|
* Test method for
|
||||||
* {@link world.bentobox.bentobox.api.commands.island.team.IslandTeamInviteCommand#canExecute(User, String, java.util.List)}.
|
* {@link world.bentobox.bentobox.api.commands.island.team.IslandTeamInviteCommand#canExecute(User, String, java.util.List)}.
|
||||||
*/
|
*/
|
||||||
|
@Ignore("PaperAPI Material issue with Material.get")
|
||||||
@Test
|
@Test
|
||||||
public void testCanExecuteNoTarget() {
|
public void testCanExecuteNoTarget() {
|
||||||
assertFalse(itl.canExecute(user, itl.getLabel(), Collections.emptyList()));
|
assertFalse(itl.canExecute(user, itl.getLabel(), Collections.emptyList()));
|
||||||
|
@ -46,7 +46,6 @@ import world.bentobox.bentobox.util.Util;
|
|||||||
* @author tastybento
|
* @author tastybento
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
@Ignore("Paper API update required")
|
|
||||||
@RunWith(PowerMockRunner.class)
|
@RunWith(PowerMockRunner.class)
|
||||||
@PrepareForTest({Bukkit.class, BentoBox.class, Util.class, ServerBuildInfo.class})
|
@PrepareForTest({Bukkit.class, BentoBox.class, Util.class, ServerBuildInfo.class})
|
||||||
public class BlockInteractionListenerTest extends AbstractCommonSetup {
|
public class BlockInteractionListenerTest extends AbstractCommonSetup {
|
||||||
@ -130,8 +129,6 @@ public class BlockInteractionListenerTest extends AbstractCommonSetup {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
*/
|
|
||||||
@Override
|
@Override
|
||||||
@Before
|
@Before
|
||||||
public void setUp() throws Exception {
|
public void setUp() throws Exception {
|
||||||
@ -147,7 +144,9 @@ public class BlockInteractionListenerTest extends AbstractCommonSetup {
|
|||||||
when(item.getType()).thenReturn(Material.AIR);
|
when(item.getType()).thenReturn(Material.AIR);
|
||||||
when(mockPlayer.getInventory()).thenReturn(inv);
|
when(mockPlayer.getInventory()).thenReturn(inv);
|
||||||
when(inv.getItemInMainHand()).thenReturn(item);
|
when(inv.getItemInMainHand()).thenReturn(item);
|
||||||
when(inv.getItemInOffHand()).thenReturn(new ItemStack(Material.BUCKET));
|
ItemStack mockBucket = mock(ItemStack.class);
|
||||||
|
when(mockBucket.getType()).thenReturn(Material.BUCKET);
|
||||||
|
when(inv.getItemInOffHand()).thenReturn(mockBucket);
|
||||||
|
|
||||||
// FlagsManager
|
// FlagsManager
|
||||||
setFlags();
|
setFlags();
|
||||||
|
@ -27,7 +27,6 @@ import org.bukkit.inventory.EquipmentSlot;
|
|||||||
import org.bukkit.inventory.ItemStack;
|
import org.bukkit.inventory.ItemStack;
|
||||||
import org.bukkit.util.Vector;
|
import org.bukkit.util.Vector;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Ignore;
|
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
import org.mockito.Mock;
|
import org.mockito.Mock;
|
||||||
@ -45,7 +44,6 @@ import world.bentobox.bentobox.util.Util;
|
|||||||
* @author tastybento
|
* @author tastybento
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
@Ignore("Needs redo for PaperAPI")
|
|
||||||
@RunWith(PowerMockRunner.class)
|
@RunWith(PowerMockRunner.class)
|
||||||
@PrepareForTest({ Bukkit.class, BentoBox.class, Util.class , ServerBuildInfo.class})
|
@PrepareForTest({ Bukkit.class, BentoBox.class, Util.class , ServerBuildInfo.class})
|
||||||
public class EntityInteractListenerTest extends AbstractCommonSetup {
|
public class EntityInteractListenerTest extends AbstractCommonSetup {
|
||||||
@ -69,7 +67,9 @@ public class EntityInteractListenerTest extends AbstractCommonSetup {
|
|||||||
// Hand - main hand
|
// Hand - main hand
|
||||||
hand = EquipmentSlot.HAND;
|
hand = EquipmentSlot.HAND;
|
||||||
position = new Vector(10, 10, 10);
|
position = new Vector(10, 10, 10);
|
||||||
when(inv.getItemInMainHand()).thenReturn(new ItemStack(Material.NAME_TAG));
|
ItemStack mockNameTag = mock(ItemStack.class);
|
||||||
|
when(mockNameTag.getType()).thenReturn(Material.NAME_TAG);
|
||||||
|
when(inv.getItemInMainHand()).thenReturn(mockNameTag);
|
||||||
|
|
||||||
// Initialize the Flags class. This is a workaround to prevent weird errors when mocking
|
// Initialize the Flags class. This is a workaround to prevent weird errors when mocking
|
||||||
// I think it's because the flag class needs to be initialized before use in argument matchers
|
// I think it's because the flag class needs to be initialized before use in argument matchers
|
||||||
@ -253,7 +253,9 @@ public class EntityInteractListenerTest extends AbstractCommonSetup {
|
|||||||
clickedEntity = mock(WanderingTrader.class);
|
clickedEntity = mock(WanderingTrader.class);
|
||||||
when(clickedEntity.getLocation()).thenReturn(location);
|
when(clickedEntity.getLocation()).thenReturn(location);
|
||||||
when(clickedEntity.getType()).thenReturn(EntityType.WANDERING_TRADER);
|
when(clickedEntity.getType()).thenReturn(EntityType.WANDERING_TRADER);
|
||||||
when(inv.getItemInMainHand()).thenReturn(new ItemStack(Material.STONE));
|
ItemStack mockStone = mock(ItemStack.class);
|
||||||
|
when(mockStone.getType()).thenReturn(Material.STONE);
|
||||||
|
when(inv.getItemInMainHand()).thenReturn(mockStone);
|
||||||
PlayerInteractEntityEvent e = new PlayerInteractEntityEvent(mockPlayer, clickedEntity, hand);
|
PlayerInteractEntityEvent e = new PlayerInteractEntityEvent(mockPlayer, clickedEntity, hand);
|
||||||
eil.onPlayerInteractEntity(e);
|
eil.onPlayerInteractEntity(e);
|
||||||
verify(notifier, never()).notify(any(), eq("protection.protected"));
|
verify(notifier, never()).notify(any(), eq("protection.protected"));
|
||||||
@ -319,7 +321,9 @@ public class EntityInteractListenerTest extends AbstractCommonSetup {
|
|||||||
clickedEntity = mock(Sheep.class);
|
clickedEntity = mock(Sheep.class);
|
||||||
when(clickedEntity.getLocation()).thenReturn(location);
|
when(clickedEntity.getLocation()).thenReturn(location);
|
||||||
when(clickedEntity.getType()).thenReturn(EntityType.SHEEP);
|
when(clickedEntity.getType()).thenReturn(EntityType.SHEEP);
|
||||||
when(inv.getItemInMainHand()).thenReturn(new ItemStack(Material.AIR));
|
ItemStack mockAir = mock(ItemStack.class);
|
||||||
|
when(mockAir.getType()).thenReturn(Material.AIR);
|
||||||
|
when(inv.getItemInMainHand()).thenReturn(mockAir);
|
||||||
PlayerInteractEntityEvent e = new PlayerInteractEntityEvent(mockPlayer, clickedEntity, hand);
|
PlayerInteractEntityEvent e = new PlayerInteractEntityEvent(mockPlayer, clickedEntity, hand);
|
||||||
eil.onPlayerInteractEntity(e);
|
eil.onPlayerInteractEntity(e);
|
||||||
verify(notifier, never()).notify(any(), eq("protection.protected"));
|
verify(notifier, never()).notify(any(), eq("protection.protected"));
|
||||||
|
@ -30,7 +30,6 @@ import org.bukkit.event.vehicle.VehicleMoveEvent;
|
|||||||
import org.bukkit.scheduler.BukkitScheduler;
|
import org.bukkit.scheduler.BukkitScheduler;
|
||||||
import org.junit.After;
|
import org.junit.After;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Ignore;
|
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
import org.mockito.Mock;
|
import org.mockito.Mock;
|
||||||
@ -56,7 +55,6 @@ import world.bentobox.bentobox.managers.PlayersManager;
|
|||||||
import world.bentobox.bentobox.mocks.ServerMocks;
|
import world.bentobox.bentobox.mocks.ServerMocks;
|
||||||
import world.bentobox.bentobox.util.Util;
|
import world.bentobox.bentobox.util.Util;
|
||||||
|
|
||||||
@Ignore("Needs PaperAPI update")
|
|
||||||
@RunWith(PowerMockRunner.class)
|
@RunWith(PowerMockRunner.class)
|
||||||
@PrepareForTest({ Bukkit.class, BentoBox.class, User.class, Util.class , ServerBuildInfo.class})
|
@PrepareForTest({ Bukkit.class, BentoBox.class, User.class, Util.class , ServerBuildInfo.class})
|
||||||
public class LockAndBanListenerTest {
|
public class LockAndBanListenerTest {
|
||||||
@ -157,6 +155,7 @@ public class LockAndBanListenerTest {
|
|||||||
when(loc.getBlockY()).thenReturn(Y);
|
when(loc.getBlockY()).thenReturn(Y);
|
||||||
when(loc.getBlockZ()).thenReturn(Z);
|
when(loc.getBlockZ()).thenReturn(Z);
|
||||||
when(island.getCenter()).thenReturn(loc);
|
when(island.getCenter()).thenReturn(loc);
|
||||||
|
when(loc.clone()).thenReturn(loc);
|
||||||
when(island.getProtectionRange()).thenReturn(PROTECTION_RANGE);
|
when(island.getProtectionRange()).thenReturn(PROTECTION_RANGE);
|
||||||
// Island is not locked by default
|
// Island is not locked by default
|
||||||
when(island.isAllowed(any(), any())).thenReturn(true);
|
when(island.isAllowed(any(), any())).thenReturn(true);
|
||||||
@ -171,16 +170,19 @@ public class LockAndBanListenerTest {
|
|||||||
when(outside.getBlockX()).thenReturn(X + PROTECTION_RANGE + 1);
|
when(outside.getBlockX()).thenReturn(X + PROTECTION_RANGE + 1);
|
||||||
when(outside.getBlockY()).thenReturn(Y);
|
when(outside.getBlockY()).thenReturn(Y);
|
||||||
when(outside.getBlockZ()).thenReturn(Z);
|
when(outside.getBlockZ()).thenReturn(Z);
|
||||||
|
when(outside.clone()).thenReturn(outside);
|
||||||
|
|
||||||
when(inside.getWorld()).thenReturn(world);
|
when(inside.getWorld()).thenReturn(world);
|
||||||
when(inside.getBlockX()).thenReturn(X + PROTECTION_RANGE - 1);
|
when(inside.getBlockX()).thenReturn(X + PROTECTION_RANGE - 1);
|
||||||
when(inside.getBlockY()).thenReturn(Y);
|
when(inside.getBlockY()).thenReturn(Y);
|
||||||
when(inside.getBlockZ()).thenReturn(Z);
|
when(inside.getBlockZ()).thenReturn(Z);
|
||||||
|
when(inside.clone()).thenReturn(inside);
|
||||||
|
|
||||||
when(inside.getWorld()).thenReturn(world);
|
when(inside2.getWorld()).thenReturn(world);
|
||||||
when(inside.getBlockX()).thenReturn(X + PROTECTION_RANGE - 2);
|
when(inside2.getBlockX()).thenReturn(X + PROTECTION_RANGE - 2);
|
||||||
when(inside.getBlockY()).thenReturn(Y);
|
when(inside2.getBlockY()).thenReturn(Y);
|
||||||
when(inside.getBlockZ()).thenReturn(Z);
|
when(inside2.getBlockZ()).thenReturn(Z);
|
||||||
|
when(inside2.clone()).thenReturn(inside2);
|
||||||
|
|
||||||
Optional<Island> opIsland = Optional.ofNullable(island);
|
Optional<Island> opIsland = Optional.ofNullable(island);
|
||||||
when(im.getProtectedIslandAt(eq(inside))).thenReturn(opIsland);
|
when(im.getProtectedIslandAt(eq(inside))).thenReturn(opIsland);
|
||||||
@ -231,6 +233,7 @@ public class LockAndBanListenerTest {
|
|||||||
assertTrue(e.isCancelled());
|
assertTrue(e.isCancelled());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("deprecation")
|
||||||
@Test
|
@Test
|
||||||
public void testLoginToBannedIsland() {
|
public void testLoginToBannedIsland() {
|
||||||
// Make player
|
// Make player
|
||||||
@ -285,11 +288,13 @@ public class LockAndBanListenerTest {
|
|||||||
when(from.getBlockX()).thenReturn(X);
|
when(from.getBlockX()).thenReturn(X);
|
||||||
when(from.getBlockY()).thenReturn(50);
|
when(from.getBlockY()).thenReturn(50);
|
||||||
when(from.getBlockZ()).thenReturn(Z);
|
when(from.getBlockZ()).thenReturn(Z);
|
||||||
|
when(from.clone()).thenReturn(from);
|
||||||
Location to = mock(Location.class);
|
Location to = mock(Location.class);
|
||||||
when(to.getWorld()).thenReturn(world);
|
when(to.getWorld()).thenReturn(world);
|
||||||
when(to.getBlockX()).thenReturn(X);
|
when(to.getBlockX()).thenReturn(X);
|
||||||
when(to.getBlockY()).thenReturn(55);
|
when(to.getBlockY()).thenReturn(55);
|
||||||
when(to.getBlockZ()).thenReturn(Z);
|
when(to.getBlockZ()).thenReturn(Z);
|
||||||
|
when(to.clone()).thenReturn(to);
|
||||||
// Create vehicle and put two players in it.
|
// Create vehicle and put two players in it.
|
||||||
Vehicle vehicle = mock(Vehicle.class);
|
Vehicle vehicle = mock(Vehicle.class);
|
||||||
Player player2 = mock(Player.class);
|
Player player2 = mock(Player.class);
|
||||||
|
@ -12,7 +12,9 @@ import static org.mockito.Mockito.verify;
|
|||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
|
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
@ -21,6 +23,8 @@ import org.bukkit.Material;
|
|||||||
import org.bukkit.World;
|
import org.bukkit.World;
|
||||||
import org.bukkit.block.Block;
|
import org.bukkit.block.Block;
|
||||||
import org.bukkit.block.BlockFace;
|
import org.bukkit.block.BlockFace;
|
||||||
|
import org.bukkit.damage.DamageSource;
|
||||||
|
import org.bukkit.damage.DamageType;
|
||||||
import org.bukkit.entity.Arrow;
|
import org.bukkit.entity.Arrow;
|
||||||
import org.bukkit.entity.Cow;
|
import org.bukkit.entity.Cow;
|
||||||
import org.bukkit.entity.Entity;
|
import org.bukkit.entity.Entity;
|
||||||
@ -33,10 +37,12 @@ import org.bukkit.event.block.Action;
|
|||||||
import org.bukkit.event.entity.EntityChangeBlockEvent;
|
import org.bukkit.event.entity.EntityChangeBlockEvent;
|
||||||
import org.bukkit.event.entity.EntityDamageByEntityEvent;
|
import org.bukkit.event.entity.EntityDamageByEntityEvent;
|
||||||
import org.bukkit.event.entity.EntityDamageEvent.DamageCause;
|
import org.bukkit.event.entity.EntityDamageEvent.DamageCause;
|
||||||
|
import org.bukkit.event.entity.EntityDamageEvent.DamageModifier;
|
||||||
import org.bukkit.event.entity.EntityExplodeEvent;
|
import org.bukkit.event.entity.EntityExplodeEvent;
|
||||||
import org.bukkit.event.player.PlayerInteractEvent;
|
import org.bukkit.event.player.PlayerInteractEvent;
|
||||||
import org.bukkit.inventory.ItemStack;
|
import org.bukkit.inventory.ItemStack;
|
||||||
import org.eclipse.jdt.annotation.Nullable;
|
import org.eclipse.jdt.annotation.Nullable;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Ignore;
|
import org.junit.Ignore;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
@ -46,6 +52,8 @@ import org.mockito.Mockito;
|
|||||||
import org.powermock.core.classloader.annotations.PrepareForTest;
|
import org.powermock.core.classloader.annotations.PrepareForTest;
|
||||||
import org.powermock.modules.junit4.PowerMockRunner;
|
import org.powermock.modules.junit4.PowerMockRunner;
|
||||||
|
|
||||||
|
import com.google.common.base.Function;
|
||||||
|
|
||||||
import io.papermc.paper.ServerBuildInfo;
|
import io.papermc.paper.ServerBuildInfo;
|
||||||
import world.bentobox.bentobox.AbstractCommonSetup;
|
import world.bentobox.bentobox.AbstractCommonSetup;
|
||||||
import world.bentobox.bentobox.BentoBox;
|
import world.bentobox.bentobox.BentoBox;
|
||||||
@ -54,7 +62,6 @@ import world.bentobox.bentobox.lists.Flags;
|
|||||||
import world.bentobox.bentobox.managers.IslandWorldManager;
|
import world.bentobox.bentobox.managers.IslandWorldManager;
|
||||||
import world.bentobox.bentobox.util.Util;
|
import world.bentobox.bentobox.util.Util;
|
||||||
|
|
||||||
@Ignore("PaperAPI changes required to fix errors and failures")
|
|
||||||
@RunWith(PowerMockRunner.class)
|
@RunWith(PowerMockRunner.class)
|
||||||
@PrepareForTest({ BentoBox.class, Util.class, Bukkit.class, ServerBuildInfo.class })
|
@PrepareForTest({ BentoBox.class, Util.class, Bukkit.class, ServerBuildInfo.class })
|
||||||
public class TNTListenerTest extends AbstractCommonSetup {
|
public class TNTListenerTest extends AbstractCommonSetup {
|
||||||
@ -112,6 +119,7 @@ public class TNTListenerTest extends AbstractCommonSetup {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@Ignore("PaperAPI error with Material isn't an item issue")
|
||||||
public void testOnTNTPriming() {
|
public void testOnTNTPriming() {
|
||||||
BlockFace clickedFace = BlockFace.DOWN;
|
BlockFace clickedFace = BlockFace.DOWN;
|
||||||
Block clickedBlock = mock(Block.class);
|
Block clickedBlock = mock(Block.class);
|
||||||
@ -324,8 +332,29 @@ public class TNTListenerTest extends AbstractCommonSetup {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testOnEntityExplosion() {
|
public void testOnEntityExplosion() {
|
||||||
EntityDamageByEntityEvent e = new EntityDamageByEntityEvent(entity, mockPlayer, DamageCause.ENTITY_EXPLOSION, null,
|
/*
|
||||||
20D);
|
* org.bukkit.event.entity.EntityDamageByEntityEvent.EntityDamageByEntityEvent(
|
||||||
|
* @NotNull @NotNull Entity damager,
|
||||||
|
* @NotNull @NotNull Entity damagee,
|
||||||
|
* @NotNull @NotNull DamageCause cause,
|
||||||
|
* @NotNull @NotNull DamageSource damageSource,
|
||||||
|
* @NotNull @NotNull Map<DamageModifier, Double> modifiers,
|
||||||
|
* @NotNull @NotNull Map<DamageModifier, ?> modifierFunctions,
|
||||||
|
* boolean critical)
|
||||||
|
|
||||||
|
Attempt to use newer event. This works but then other errors appear. Go figure.
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
Map<DamageModifier, Double> modifiers = new HashMap<>();
|
||||||
|
modifiers.put(DamageModifier.BASE, 0.0D);
|
||||||
|
@NotNull
|
||||||
|
Map<DamageModifier, ? extends Function<? super Double, Double>> modifier = new HashMap<>();
|
||||||
|
modifier.put(DamageModifier.BASE, null);
|
||||||
|
EntityDamageByEntityEvent e = new EntityDamageByEntityEvent(entity, mockPlayer, DamageCause.ENTITY_EXPLOSION,
|
||||||
|
DamageSource.builder(DamageType.EXPLOSION).build(), modifiers, modifier, false);
|
||||||
|
*/
|
||||||
|
EntityDamageByEntityEvent e = new EntityDamageByEntityEvent(entity, mockPlayer, DamageCause.ENTITY_EXPLOSION,
|
||||||
|
null, 20D);
|
||||||
listener.onExplosion(e);
|
listener.onExplosion(e);
|
||||||
assertTrue(e.isCancelled());
|
assertTrue(e.isCancelled());
|
||||||
}
|
}
|
||||||
|
@ -34,7 +34,6 @@ import org.bukkit.inventory.meta.SkullMeta;
|
|||||||
import org.bukkit.plugin.PluginManager;
|
import org.bukkit.plugin.PluginManager;
|
||||||
import org.junit.After;
|
import org.junit.After;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Ignore;
|
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
import org.mockito.Mockito;
|
import org.mockito.Mockito;
|
||||||
@ -68,7 +67,6 @@ import world.bentobox.bentobox.util.Util;
|
|||||||
public class ChestDamageListenerTest extends AbstractCommonSetup
|
public class ChestDamageListenerTest extends AbstractCommonSetup
|
||||||
{
|
{
|
||||||
|
|
||||||
private Location location;
|
|
||||||
private BentoBox plugin;
|
private BentoBox plugin;
|
||||||
private World world;
|
private World world;
|
||||||
|
|
||||||
@ -104,11 +102,7 @@ public class ChestDamageListenerTest extends AbstractCommonSetup
|
|||||||
when(itemFactory.getItemMeta(any())).thenReturn(skullMeta);
|
when(itemFactory.getItemMeta(any())).thenReturn(skullMeta);
|
||||||
when(Bukkit.getItemFactory()).thenReturn(itemFactory);
|
when(Bukkit.getItemFactory()).thenReturn(itemFactory);
|
||||||
when(Bukkit.getLogger()).thenReturn(Logger.getAnonymousLogger());
|
when(Bukkit.getLogger()).thenReturn(Logger.getAnonymousLogger());
|
||||||
location = mock(Location.class);
|
|
||||||
when(location.getWorld()).thenReturn(world);
|
|
||||||
when(location.getBlockX()).thenReturn(0);
|
|
||||||
when(location.getBlockY()).thenReturn(0);
|
|
||||||
when(location.getBlockZ()).thenReturn(0);
|
|
||||||
PowerMockito.mockStatic(Flags.class);
|
PowerMockito.mockStatic(Flags.class);
|
||||||
|
|
||||||
FlagsManager flagsManager = new FlagsManager(plugin);
|
FlagsManager flagsManager = new FlagsManager(plugin);
|
||||||
@ -180,28 +174,37 @@ public class ChestDamageListenerTest extends AbstractCommonSetup
|
|||||||
* Test method for {@link ChestDamageListener#onExplosion(org.bukkit.event.entity.EntityExplodeEvent)}.
|
* Test method for {@link ChestDamageListener#onExplosion(org.bukkit.event.entity.EntityExplodeEvent)}.
|
||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
@Ignore("Fixes required for failures PaperAPI")
|
|
||||||
public void testOnExplosionChestDamageNotAllowed() {
|
public void testOnExplosionChestDamageNotAllowed() {
|
||||||
|
// Srt the flag to not allow chest damage
|
||||||
Flags.CHEST_DAMAGE.setSetting(world, false);
|
Flags.CHEST_DAMAGE.setSetting(world, false);
|
||||||
|
// Set the entity that is causing the damage (TNT)
|
||||||
Entity entity = mock(Entity.class);
|
Entity entity = mock(Entity.class);
|
||||||
when(entity.getType()).thenReturn(EntityType.TNT);
|
when(entity.getType()).thenReturn(EntityType.TNT);
|
||||||
|
|
||||||
|
// Create a list of blocks that will potentially be damaged by TNT
|
||||||
List<Block> list = new ArrayList<>();
|
List<Block> list = new ArrayList<>();
|
||||||
Block chest = mock(Block.class);
|
Block chest = mock(Block.class);
|
||||||
when(chest.getType()).thenReturn(Material.CHEST);
|
when(chest.getType()).thenReturn(Material.CHEST); // Regular chest
|
||||||
when(chest.getLocation()).thenReturn(location);
|
when(chest.getLocation()).thenReturn(location);
|
||||||
|
|
||||||
Block trappedChest = mock(Block.class);
|
Block trappedChest = mock(Block.class);
|
||||||
when(trappedChest.getType()).thenReturn(Material.TRAPPED_CHEST);
|
when(trappedChest.getType()).thenReturn(Material.TRAPPED_CHEST);// Trapped chest
|
||||||
when(trappedChest.getLocation()).thenReturn(location);
|
when(trappedChest.getLocation()).thenReturn(location);
|
||||||
|
|
||||||
Block stone = mock(Block.class);
|
Block stone = mock(Block.class);
|
||||||
when(stone.getType()).thenReturn(Material.STONE);
|
when(stone.getType()).thenReturn(Material.STONE); // Stone
|
||||||
when(stone.getLocation()).thenReturn(location);
|
when(stone.getLocation()).thenReturn(location);
|
||||||
list.add(chest);
|
list.add(chest);
|
||||||
list.add(trappedChest);
|
list.add(trappedChest);
|
||||||
list.add(stone);
|
list.add(stone);
|
||||||
|
// Create the event
|
||||||
EntityExplodeEvent e = getExplodeEvent(entity, location, list);
|
EntityExplodeEvent e = getExplodeEvent(entity, location, list);
|
||||||
|
// Listener to test
|
||||||
ChestDamageListener listener = new ChestDamageListener();
|
ChestDamageListener listener = new ChestDamageListener();
|
||||||
listener.setPlugin(plugin);
|
listener.setPlugin(plugin);
|
||||||
listener.onExplosion(e);
|
listener.onExplosion(e);
|
||||||
|
|
||||||
|
// Verify
|
||||||
assertFalse(e.isCancelled());
|
assertFalse(e.isCancelled());
|
||||||
assertEquals(1, e.blockList().size());
|
assertEquals(1, e.blockList().size());
|
||||||
assertFalse(e.blockList().contains(chest));
|
assertFalse(e.blockList().contains(chest));
|
||||||
|
@ -24,7 +24,6 @@ import org.bukkit.event.entity.EntityExplodeEvent;
|
|||||||
import org.eclipse.jdt.annotation.Nullable;
|
import org.eclipse.jdt.annotation.Nullable;
|
||||||
import org.junit.After;
|
import org.junit.After;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Ignore;
|
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
import org.mockito.Mock;
|
import org.mockito.Mock;
|
||||||
@ -52,8 +51,6 @@ public class WitherListenerTest extends AbstractCommonSetup {
|
|||||||
|
|
||||||
private WitherListener wl;
|
private WitherListener wl;
|
||||||
@Mock
|
@Mock
|
||||||
private Location location;
|
|
||||||
@Mock
|
|
||||||
private Location location2;
|
private Location location2;
|
||||||
@Mock
|
@Mock
|
||||||
private World world;
|
private World world;
|
||||||
@ -82,15 +79,11 @@ public class WitherListenerTest extends AbstractCommonSetup {
|
|||||||
when(ws.getWorldFlags()).thenReturn(map);
|
when(ws.getWorldFlags()).thenReturn(map);
|
||||||
when(iwm.getWorldSettings(any())).thenReturn(ws);
|
when(iwm.getWorldSettings(any())).thenReturn(ws);
|
||||||
|
|
||||||
when(location.getWorld()).thenReturn(world);
|
|
||||||
when(location.getBlockX()).thenReturn(0);
|
|
||||||
when(location.getBlockY()).thenReturn(0);
|
|
||||||
when(location.getBlockZ()).thenReturn(0);
|
|
||||||
|
|
||||||
when(location2.getWorld()).thenReturn(world2);
|
when(location2.getWorld()).thenReturn(world2);
|
||||||
when(location2.getBlockX()).thenReturn(0);
|
when(location2.getBlockX()).thenReturn(0);
|
||||||
when(location2.getBlockY()).thenReturn(0);
|
when(location2.getBlockY()).thenReturn(0);
|
||||||
when(location2.getBlockZ()).thenReturn(0);
|
when(location2.getBlockZ()).thenReturn(0);
|
||||||
|
when(location2.clone()).thenReturn(location2); // Paper
|
||||||
|
|
||||||
blocks = new ArrayList<>();
|
blocks = new ArrayList<>();
|
||||||
for (int i = 0; i < 4; i++) {
|
for (int i = 0; i < 4; i++) {
|
||||||
@ -119,12 +112,12 @@ public class WitherListenerTest extends AbstractCommonSetup {
|
|||||||
* Test method for {@link world.bentobox.bentobox.listeners.flags.worldsettings.WitherListener#onExplosion(org.bukkit.event.entity.EntityExplodeEvent)}.
|
* Test method for {@link world.bentobox.bentobox.listeners.flags.worldsettings.WitherListener#onExplosion(org.bukkit.event.entity.EntityExplodeEvent)}.
|
||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
@Ignore("Fixes required for failures PaperAPI")
|
|
||||||
public void testOnExplosionWither() {
|
public void testOnExplosionWither() {
|
||||||
Entity entity = mock(Entity.class);
|
Entity entity = mock(Entity.class);
|
||||||
when(entity.getLocation()).thenReturn(location);
|
when(entity.getLocation()).thenReturn(location);
|
||||||
when(entity.getWorld()).thenReturn(world);
|
when(entity.getWorld()).thenReturn(world);
|
||||||
when(entity.getType()).thenReturn(EntityType.WITHER);
|
when(entity.getType()).thenReturn(EntityType.WITHER);
|
||||||
|
when(location.clone()).thenReturn(location);
|
||||||
EntityExplodeEvent e = getExplodeEvent(entity, location, blocks);
|
EntityExplodeEvent e = getExplodeEvent(entity, location, blocks);
|
||||||
wl.onExplosion(e);
|
wl.onExplosion(e);
|
||||||
assertTrue(blocks.isEmpty());
|
assertTrue(blocks.isEmpty());
|
||||||
@ -165,12 +158,12 @@ public class WitherListenerTest extends AbstractCommonSetup {
|
|||||||
* Test method for {@link world.bentobox.bentobox.listeners.flags.worldsettings.WitherListener#onExplosion(org.bukkit.event.entity.EntityExplodeEvent)}.
|
* Test method for {@link world.bentobox.bentobox.listeners.flags.worldsettings.WitherListener#onExplosion(org.bukkit.event.entity.EntityExplodeEvent)}.
|
||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
@Ignore("Fixes required for failures PaperAPI")
|
|
||||||
public void testOnExplosionWitherSkull() {
|
public void testOnExplosionWitherSkull() {
|
||||||
Entity entity = mock(Entity.class);
|
Entity entity = mock(Entity.class);
|
||||||
when(entity.getLocation()).thenReturn(location);
|
when(entity.getLocation()).thenReturn(location);
|
||||||
when(entity.getWorld()).thenReturn(world);
|
when(entity.getWorld()).thenReturn(world);
|
||||||
when(entity.getType()).thenReturn(EntityType.WITHER_SKULL);
|
when(entity.getType()).thenReturn(EntityType.WITHER_SKULL);
|
||||||
|
when(location.clone()).thenReturn(location);
|
||||||
EntityExplodeEvent e = getExplodeEvent(entity, location, blocks);
|
EntityExplodeEvent e = getExplodeEvent(entity, location, blocks);
|
||||||
wl.onExplosion(e);
|
wl.onExplosion(e);
|
||||||
assertTrue(blocks.isEmpty());
|
assertTrue(blocks.isEmpty());
|
||||||
|
Loading…
Reference in New Issue
Block a user