Skip to content

Commit

Permalink
Fix another bug with interaction fix and add more interaction tests (#…
Browse files Browse the repository at this point in the history
  • Loading branch information
WalshyDev authored Jan 14, 2024
1 parent 86533a8 commit 1fb27b9
Show file tree
Hide file tree
Showing 2 changed files with 93 additions and 11 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,7 @@
import io.github.thebusybiscuit.slimefun4.utils.tags.SlimefunTag;

import me.mrCookieSlime.Slimefun.api.BlockStorage;
import me.mrCookieSlime.Slimefun.api.inventory.BlockMenu;

/**
* The {@link BlockListener} is responsible for listening to the {@link BlockPlaceEvent}
Expand Down Expand Up @@ -224,9 +225,10 @@ private void callBlockHandler(BlockBreakEvent e, ItemStack item, List<ItemStack>
// Partial fix for #4087 - We don't want the inventory to be usable post break, close it for anyone still inside
// The main fix is in SlimefunItemInteractListener preventing opening to begin with
// Close the inventory for all viewers of this block
BlockMenu inventory = BlockStorage.getInventory(e.getBlock());
// TODO(future): Remove this check when MockBukkit supports viewers
if (!Slimefun.instance().isUnitTest()) {
BlockStorage.getInventory(e.getBlock()).toInventory().getViewers().forEach(HumanEntity::closeInventory);
if (inventory != null && !Slimefun.instance().isUnitTest()) {
inventory.toInventory().getViewers().forEach(HumanEntity::closeInventory);
}
// Remove the block data
BlockStorage.clearBlockInfo(e.getBlock());
Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
package io.github.thebusybiscuit.slimefun4.implementation.listeners;

import io.github.thebusybiscuit.slimefun4.api.events.SlimefunBlockBreakEvent;
import org.bukkit.World;
import org.bukkit.block.Block;
import org.bukkit.block.BlockFace;
Expand All @@ -17,23 +16,34 @@
import org.junit.jupiter.api.BeforeAll;
import org.junit.jupiter.api.Test;

import io.github.bakedlibs.dough.common.ChatColors;
import io.github.thebusybiscuit.slimefun4.api.events.PlayerRightClickEvent;
import io.github.thebusybiscuit.slimefun4.api.events.SlimefunBlockBreakEvent;
import io.github.thebusybiscuit.slimefun4.api.items.ItemGroup;
import io.github.thebusybiscuit.slimefun4.api.items.SlimefunItem;
import io.github.thebusybiscuit.slimefun4.api.recipes.RecipeType;
import io.github.thebusybiscuit.slimefun4.implementation.Slimefun;
import io.github.thebusybiscuit.slimefun4.implementation.SlimefunItems;
import io.github.thebusybiscuit.slimefun4.implementation.items.electric.EnergyConnector;
import io.github.thebusybiscuit.slimefun4.implementation.items.electric.machines.ElectricFurnace;
import io.github.thebusybiscuit.slimefun4.implementation.items.magical.staves.WindStaff;
import io.github.thebusybiscuit.slimefun4.test.TestUtilities;
import me.mrCookieSlime.Slimefun.api.BlockStorage;
import me.mrCookieSlime.Slimefun.api.inventory.BlockMenuPreset;
import be.seeseemelk.mockbukkit.MockBukkit;
import be.seeseemelk.mockbukkit.ServerMock;
import be.seeseemelk.mockbukkit.entity.PlayerMock;

class TestSlimefunItemInteractListener {

private static ServerMock server;
private static Slimefun plugin;
private static SlimefunItem slimefunItem;
// Block with inventory
private static SlimefunItem electricFurnace;
// Interactable block
private static SlimefunItem energyConnector;
// Interactable item
private static SlimefunItem windStaff;

@BeforeAll
public static void load() {
Expand All @@ -47,13 +57,19 @@ public static void load() {
// Enable tickers so the electric furnace can be registered
Slimefun.getCfg().setValue("URID.enable-tickers", true);

slimefunItem = new ElectricFurnace(
TestUtilities.getItemGroup(plugin, "test"), SlimefunItems.ELECTRIC_FURNACE, RecipeType.NULL, new ItemStack[]{}
)
ItemGroup testGroup = TestUtilities.getItemGroup(plugin, "test");

electricFurnace = new ElectricFurnace(testGroup, SlimefunItems.ELECTRIC_FURNACE, RecipeType.NULL, new ItemStack[]{})
.setCapacity(100)
.setEnergyConsumption(10)
.setProcessingSpeed(1);
slimefunItem.register(plugin);
electricFurnace.register(plugin);

energyConnector = new EnergyConnector(testGroup, SlimefunItems.ENERGY_CONNECTOR, RecipeType.NULL, new ItemStack[9], null);
energyConnector.register(plugin);

windStaff = new WindStaff(testGroup, SlimefunItems.STAFF_WIND, RecipeType.NULL, new ItemStack[9]);
windStaff.register(plugin);
}

@AfterAll
Expand All @@ -71,7 +87,7 @@ public void afterEach() {
void testCannotOpenInvOfBrokenBlock() {
// Place down an electric furnace
Player player = server.addPlayer();
ItemStack itemStack = slimefunItem.getItem();
ItemStack itemStack = electricFurnace.getItem();
player.getInventory().setItemInMainHand(itemStack);

// Create a world and place the block
Expand All @@ -98,15 +114,15 @@ void testCannotOpenInvOfBrokenBlock() {

// Assert we do have an inventory which would be opened
// TODO: Create an event for open inventory so this isn't guess work
Assertions.assertTrue(BlockMenuPreset.isInventory(slimefunItem.getId()));
Assertions.assertTrue(BlockMenuPreset.isInventory(electricFurnace.getId()));
Assertions.assertTrue(BlockStorage.getStorage(block.getWorld()).hasInventory(block.getLocation()));
// TODO(future): Check viewers - MockBukkit does not implement this today

// Break the block
BlockBreakEvent blockBreakEvent = new BlockBreakEvent(block, player);
server.getPluginManager().callEvent(blockBreakEvent);
server.getPluginManager().assertEventFired(SlimefunBlockBreakEvent.class, e -> {
Assertions.assertEquals(slimefunItem.getId(), e.getSlimefunItem().getId());
Assertions.assertEquals(electricFurnace.getId(), e.getSlimefunItem().getId());
return true;
});

Expand Down Expand Up @@ -134,4 +150,68 @@ void testCannotOpenInvOfBrokenBlock() {
() -> server.getPluginManager().assertEventFired(PlayerRightClickEvent.class, e -> true)
);
}

@Test
void testRightClickItem() {
Player player = server.addPlayer();
ItemStack itemStack = windStaff.getItem();
player.getInventory().setItemInMainHand(itemStack);

// Assert player is at full food level (wind staff reduces food level on usage)
Assertions.assertEquals(20, player.getFoodLevel());

// Right click the air
PlayerInteractEvent playerInteractEvent = new PlayerInteractEvent(
player, Action.RIGHT_CLICK_AIR, itemStack, null, BlockFace.UP, EquipmentSlot.HAND
);

server.getPluginManager().callEvent(playerInteractEvent);
server.getPluginManager().assertEventFired(PlayerInteractEvent.class, e -> {
// Assert our interaction was not cancelled
Assertions.assertNotSame(e.useItemInHand(), Result.DENY);
return true;
});

// Assert our right click event fired and the item usage was not denied
server.getPluginManager().assertEventFired(PlayerRightClickEvent.class, e -> {
Assertions.assertNotSame(e.useItem(), Result.DENY);
return true;
});

// Assert our food level is now 18
Assertions.assertEquals(18, player.getFoodLevel());
}

@Test
void testRightClickInteractableBlock() {
// Place down an energy connector
PlayerMock player = server.addPlayer();
ItemStack itemStack = energyConnector.getItem();
player.getInventory().setItemInMainHand(itemStack);

// Create a world and place the block
World world = TestUtilities.createWorld(server);
Block block = TestUtilities.placeSlimefunBlock(server, itemStack, world, player);

// Right click on the block
PlayerInteractEvent playerInteractEvent = new PlayerInteractEvent(
player, Action.RIGHT_CLICK_BLOCK, itemStack, block, BlockFace.UP, EquipmentSlot.HAND
);

server.getPluginManager().callEvent(playerInteractEvent);
server.getPluginManager().assertEventFired(PlayerInteractEvent.class, e -> {
// Allow interaction of the block
Assertions.assertSame(e.useInteractedBlock(), Result.ALLOW);
return true;
});

// Assert our right click event fired and the block usage was not denied
server.getPluginManager().assertEventFired(PlayerRightClickEvent.class, e -> {
Assertions.assertNotSame(e.useBlock(), Result.DENY);
return true;
});

// Assert the message our energy connector sends
Assertions.assertEquals(ChatColors.color("&7Connected: " + "&4\u2718"), player.nextMessage());
}
}

0 comments on commit 1fb27b9

Please sign in to comment.