mirror of
https://github.com/BentoBoxWorld/BentoBox.git
synced 2024-09-29 23:27:30 +02:00
Added AdminBlueprintLoadCommand test class
This commit is contained in:
parent
04545e676f
commit
5eaf54e905
@ -34,7 +34,6 @@ import world.bentobox.bentobox.BentoBox;
|
|||||||
import world.bentobox.bentobox.Settings;
|
import world.bentobox.bentobox.Settings;
|
||||||
import world.bentobox.bentobox.api.addons.GameModeAddon;
|
import world.bentobox.bentobox.api.addons.GameModeAddon;
|
||||||
import world.bentobox.bentobox.api.user.User;
|
import world.bentobox.bentobox.api.user.User;
|
||||||
import world.bentobox.bentobox.blueprints.Blueprint;
|
|
||||||
import world.bentobox.bentobox.blueprints.BlueprintClipboard;
|
import world.bentobox.bentobox.blueprints.BlueprintClipboard;
|
||||||
import world.bentobox.bentobox.managers.BlueprintsManager;
|
import world.bentobox.bentobox.managers.BlueprintsManager;
|
||||||
import world.bentobox.bentobox.managers.CommandsManager;
|
import world.bentobox.bentobox.managers.CommandsManager;
|
||||||
@ -59,7 +58,6 @@ public class AdminBlueprintCopyCommandTest {
|
|||||||
private UUID uuid = UUID.randomUUID();
|
private UUID uuid = UUID.randomUUID();
|
||||||
@Mock
|
@Mock
|
||||||
private BlueprintsManager bm;
|
private BlueprintsManager bm;
|
||||||
private Blueprint bp = new Blueprint();
|
|
||||||
private AdminBlueprintCopyCommand abcc;
|
private AdminBlueprintCopyCommand abcc;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -0,0 +1,202 @@
|
|||||||
|
package world.bentobox.bentobox.api.commands.admin.blueprints;
|
||||||
|
|
||||||
|
import static org.junit.Assert.*;
|
||||||
|
import static org.mockito.ArgumentMatchers.any;
|
||||||
|
import static org.mockito.ArgumentMatchers.anyString;
|
||||||
|
import static org.mockito.Mockito.mock;
|
||||||
|
import static org.mockito.Mockito.verify;
|
||||||
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.nio.file.Files;
|
||||||
|
import java.nio.file.Path;
|
||||||
|
import java.nio.file.StandardCopyOption;
|
||||||
|
import java.util.Comparator;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.Optional;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.junit.After;
|
||||||
|
import org.junit.Before;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.mockito.Mock;
|
||||||
|
import org.mockito.Mockito;
|
||||||
|
import org.powermock.api.mockito.PowerMockito;
|
||||||
|
import org.powermock.core.classloader.annotations.PrepareForTest;
|
||||||
|
import org.powermock.modules.junit4.PowerMockRunner;
|
||||||
|
import org.powermock.reflect.Whitebox;
|
||||||
|
|
||||||
|
import world.bentobox.bentobox.BentoBox;
|
||||||
|
import world.bentobox.bentobox.Settings;
|
||||||
|
import world.bentobox.bentobox.api.addons.GameModeAddon;
|
||||||
|
import world.bentobox.bentobox.api.localization.TextVariables;
|
||||||
|
import world.bentobox.bentobox.api.user.User;
|
||||||
|
import world.bentobox.bentobox.blueprints.Blueprint;
|
||||||
|
import world.bentobox.bentobox.managers.BlueprintsManager;
|
||||||
|
import world.bentobox.bentobox.managers.CommandsManager;
|
||||||
|
import world.bentobox.bentobox.managers.LocalesManager;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author tastybento
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
@RunWith(PowerMockRunner.class)
|
||||||
|
@PrepareForTest({Bukkit.class, BentoBox.class, User.class })
|
||||||
|
public class AdminBlueprintLoadCommandTest {
|
||||||
|
|
||||||
|
@Mock
|
||||||
|
BentoBox plugin;
|
||||||
|
@Mock
|
||||||
|
private AdminBlueprintCommand ac;
|
||||||
|
@Mock
|
||||||
|
private GameModeAddon addon;
|
||||||
|
@Mock
|
||||||
|
private User user;
|
||||||
|
private UUID uuid = UUID.randomUUID();
|
||||||
|
@Mock
|
||||||
|
private BlueprintsManager bm;
|
||||||
|
private Blueprint bp = new Blueprint();
|
||||||
|
private AdminBlueprintLoadCommand abcc;
|
||||||
|
private Map<String, Blueprint> map;
|
||||||
|
private File blueprintsFolder;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @throws java.lang.Exception
|
||||||
|
*/
|
||||||
|
@Before
|
||||||
|
public void setUp() throws Exception {
|
||||||
|
// Set up plugin
|
||||||
|
Whitebox.setInternalState(BentoBox.class, "instance", plugin);
|
||||||
|
|
||||||
|
// Blueprints Manager
|
||||||
|
when(plugin.getBlueprintsManager()).thenReturn(bm);
|
||||||
|
|
||||||
|
// Command manager
|
||||||
|
CommandsManager cm = mock(CommandsManager.class);
|
||||||
|
when(plugin.getCommandsManager()).thenReturn(cm);
|
||||||
|
|
||||||
|
// Settings
|
||||||
|
Settings s = mock(Settings.class);
|
||||||
|
when(s.getResetCooldown()).thenReturn(0);
|
||||||
|
when(plugin.getSettings()).thenReturn(s);
|
||||||
|
|
||||||
|
// Sometimes use Mockito.withSettings().verboseLogging()
|
||||||
|
User.setPlugin(plugin);
|
||||||
|
when(user.getUniqueId()).thenReturn(uuid);
|
||||||
|
when(user.getTranslation(anyString())).thenReturn("translation");
|
||||||
|
|
||||||
|
// Parent command
|
||||||
|
when(ac.getAddon()).thenReturn(addon);
|
||||||
|
when(ac.getLabel()).thenReturn("blueprint");
|
||||||
|
when(ac.getSubCommandAliases()).thenReturn(new HashMap<>());
|
||||||
|
when(ac.getTopLabel()).thenReturn("admin");
|
||||||
|
|
||||||
|
map = new HashMap<>();
|
||||||
|
map.put("key", bp);
|
||||||
|
when(bm.getBlueprints(any())).thenReturn(map);
|
||||||
|
blueprintsFolder = new File("blueprints");
|
||||||
|
File blueprint = new File(blueprintsFolder, "island.blu");
|
||||||
|
blueprint.mkdirs();
|
||||||
|
blueprint.createNewFile();
|
||||||
|
File source = new File("src/test/java/world/bentobox/bentobox/api/commands/admin/blueprints", "island.blu");
|
||||||
|
Files.copy(source.toPath(), blueprint.toPath(), StandardCopyOption.REPLACE_EXISTING);
|
||||||
|
when(ac.getBlueprintsFolder()).thenReturn(blueprintsFolder);
|
||||||
|
|
||||||
|
// Locales
|
||||||
|
LocalesManager lm = mock(LocalesManager.class);
|
||||||
|
when(lm.get(Mockito.any(), Mockito.any())).thenReturn("mock translation");
|
||||||
|
when(plugin.getLocalesManager()).thenReturn(lm);
|
||||||
|
|
||||||
|
PowerMockito.mockStatic(Bukkit.class, Mockito.RETURNS_MOCKS);
|
||||||
|
|
||||||
|
|
||||||
|
abcc = new AdminBlueprintLoadCommand(ac);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @throws java.lang.Exception
|
||||||
|
*/
|
||||||
|
@After
|
||||||
|
public void tearDown() throws Exception {
|
||||||
|
User.clearUsers();
|
||||||
|
Mockito.framework().clearInlineMocks();
|
||||||
|
|
||||||
|
if (blueprintsFolder.exists()) {
|
||||||
|
Files.walk(blueprintsFolder.toPath())
|
||||||
|
.sorted(Comparator.reverseOrder())
|
||||||
|
.map(Path::toFile)
|
||||||
|
.forEach(File::delete);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test method for {@link world.bentobox.bentobox.api.commands.admin.blueprints.AdminBlueprintLoadCommand#AdminBlueprintLoadCommand(world.bentobox.bentobox.api.commands.admin.blueprints.AdminBlueprintCommand)}.
|
||||||
|
*/
|
||||||
|
@Test
|
||||||
|
public void testAdminBlueprintLoadCommand() {
|
||||||
|
assertNotNull(abcc);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test method for {@link world.bentobox.bentobox.api.commands.admin.blueprints.AdminBlueprintLoadCommand#setup()}.
|
||||||
|
*/
|
||||||
|
@Test
|
||||||
|
public void testSetup() {
|
||||||
|
abcc.setup();
|
||||||
|
assertEquals("commands.admin.blueprint.load.description", abcc.getDescription());
|
||||||
|
assertEquals("commands.admin.blueprint.load.parameters", abcc.getParameters());
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test method for {@link world.bentobox.bentobox.api.commands.admin.blueprints.AdminBlueprintLoadCommand#execute(world.bentobox.bentobox.api.user.User, java.lang.String, java.util.List)}.
|
||||||
|
*/
|
||||||
|
@Test
|
||||||
|
public void testExecuteUserStringListOfStringHelp() {
|
||||||
|
assertFalse(abcc.execute(user, "", List.of("1", "2", "3")));
|
||||||
|
verify(user).sendMessage("commands.help.header", "[label]", "translation");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test method for {@link world.bentobox.bentobox.api.commands.admin.blueprints.AdminBlueprintLoadCommand#execute(world.bentobox.bentobox.api.user.User, java.lang.String, java.util.List)}.
|
||||||
|
*/
|
||||||
|
@Test
|
||||||
|
public void testExecuteUserStringListOfStringNoLoad() {
|
||||||
|
assertFalse(abcc.execute(user, "", List.of(" iSlAnd ")));
|
||||||
|
verify(user).sendMessage("commands.admin.blueprint.could-not-load");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test method for {@link world.bentobox.bentobox.api.commands.admin.blueprints.AdminBlueprintLoadCommand#execute(world.bentobox.bentobox.api.user.User, java.lang.String, java.util.List)}.
|
||||||
|
*/
|
||||||
|
@Test
|
||||||
|
public void testExecuteUserStringListOfStringSuccessCaps() {
|
||||||
|
assertTrue(abcc.execute(user, "", List.of("island")));
|
||||||
|
verify(user).sendMessage("general.success");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test method for {@link world.bentobox.bentobox.api.commands.admin.blueprints.AdminBlueprintLoadCommand#tabComplete(world.bentobox.bentobox.api.user.User, java.lang.String, java.util.List)}.
|
||||||
|
*/
|
||||||
|
@Test
|
||||||
|
public void testTabCompleteUserStringListOfString() {
|
||||||
|
Optional<List<String>> o = abcc.tabComplete(user, "", List.of(""));
|
||||||
|
assertTrue(o.isPresent());
|
||||||
|
assertEquals("island", o.get().get(0));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test method for {@link world.bentobox.bentobox.api.commands.admin.blueprints.AdminBlueprintLoadCommand#tabComplete(world.bentobox.bentobox.api.user.User, java.lang.String, java.util.List)}.
|
||||||
|
*/
|
||||||
|
@Test
|
||||||
|
public void testTabCompleteUserStringListOfStringIsland() {
|
||||||
|
Optional<List<String>> o = abcc.tabComplete(user, "", List.of("e"));
|
||||||
|
assertTrue(o.isPresent());
|
||||||
|
assertEquals("end-island", o.get().get(0));
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Binary file not shown.
Loading…
Reference in New Issue
Block a user