Remove deprecated BlockInfo in favor of Location/BlockState

BlockInfo kept making me cringe every time I had to look at the code. More importantly it only had support for storing item IDs and no data. It was way obsolete versus new API.
This commit is contained in:
cmastudios 2013-10-05 02:04:28 -05:00
parent 6e9efc7a8a
commit 1722c86a71
18 changed files with 452 additions and 1050 deletions

View File

@ -39,6 +39,9 @@
<url>http://ci.tommytony.com</url> <url>http://ci.tommytony.com</url>
</ciManagement> </ciManagement>
<scm> <scm>
<connection>scm:git:git://github.com/taoneill/war.git</connection>
<developerConnection>scm:git:git@github.com:taoneill/war.git</developerConnection>
<tag>HEAD</tag>
<url>https://github.com/taoneill/war</url> <url>https://github.com/taoneill/war</url>
</scm> </scm>
<build> <build>

View File

@ -36,7 +36,6 @@ import com.tommytony.war.config.TeamSpawnStyle;
import com.tommytony.war.structure.Bomb; import com.tommytony.war.structure.Bomb;
import com.tommytony.war.structure.Cake; import com.tommytony.war.structure.Cake;
import com.tommytony.war.utility.Direction; import com.tommytony.war.utility.Direction;
import com.tommytony.war.volume.BlockInfo;
import com.tommytony.war.volume.Volume; import com.tommytony.war.volume.Volume;
/** /**
@ -580,19 +579,13 @@ public class Team {
public void initializeTeamFlag() { public void initializeTeamFlag() {
// make air (old two-high above floor) // make air (old two-high above floor)
Volume airGap = new Volume("airgap", this.warzone.getWorld()); Volume airGap = new Volume(new Location(this.flagVolume.getWorld(),
airGap.setCornerOne(new BlockInfo( this.flagVolume.getCornerOne().getX(), this.flagVolume
this.flagVolume.getCornerOne().getX(), .getCornerOne().getY() + 1, this.flagVolume
this.flagVolume.getCornerOne().getY() + 1, .getCornerOne().getZ()), new Location(
this.flagVolume.getCornerOne().getZ(), this.flagVolume.getWorld(), this.flagVolume.getCornerTwo()
0, .getX(), this.flagVolume.getCornerOne().getY() + 2,
(byte)0)); this.flagVolume.getCornerTwo().getZ()));
airGap.setCornerTwo(new BlockInfo(
this.flagVolume.getCornerTwo().getX(),
this.flagVolume.getCornerOne().getY() + 2,
this.flagVolume.getCornerTwo().getZ(),
0,
(byte)0));
airGap.setToMaterial(Material.AIR); airGap.setToMaterial(Material.AIR);
// Set the flag blocks // Set the flag blocks

View File

@ -61,7 +61,6 @@ import com.tommytony.war.utility.Loadout;
import com.tommytony.war.utility.LoadoutSelection; import com.tommytony.war.utility.LoadoutSelection;
import com.tommytony.war.utility.PlayerState; import com.tommytony.war.utility.PlayerState;
import com.tommytony.war.utility.PotionEffectHelper; import com.tommytony.war.utility.PotionEffectHelper;
import com.tommytony.war.volume.BlockInfo;
import com.tommytony.war.volume.Volume; import com.tommytony.war.volume.Volume;
import com.tommytony.war.volume.ZoneVolume; import com.tommytony.war.volume.ZoneVolume;
@ -252,11 +251,11 @@ public class Warzone {
} }
} }
int saved = this.volume.saveBlocks(); this.volume.saveBlocks();
if (clearArtifacts) { if (clearArtifacts) {
this.initializeZone(); // bring back stuff this.initializeZone(); // bring back stuff
} }
return saved; return this.volume.size();
} }
return 0; return 0;
} }
@ -1552,10 +1551,15 @@ public class Warzone {
for (Team maybeOpponent : this.getTeams()) { for (Team maybeOpponent : this.getTeams()) {
if (maybeOpponent != team) { if (maybeOpponent != team) {
for (Volume teamSpawnVolume : maybeOpponent.getSpawnVolumes().values()) { for (Volume teamSpawnVolume : maybeOpponent.getSpawnVolumes().values()) {
Volume periphery = new Volume("periphery", this.getWorld()); Volume periphery = new Volume(new Location(
periphery.setCornerOne(new BlockInfo(teamSpawnVolume.getMinX()-1 , teamSpawnVolume.getMinY()-1, teamSpawnVolume.getMinZ()-1, 0, (byte)0)); teamSpawnVolume.getWorld(),
periphery.setCornerTwo(new BlockInfo(teamSpawnVolume.getMaxX()+1, teamSpawnVolume.getMaxY()+1, teamSpawnVolume.getMaxZ()+1, 0, (byte)0)); teamSpawnVolume.getMinX() - 1,
teamSpawnVolume.getMinY() - 1,
teamSpawnVolume.getMinZ() - 1), new Location(
teamSpawnVolume.getWorld(),
teamSpawnVolume.getMaxX() + 1,
teamSpawnVolume.getMaxY() + 1,
teamSpawnVolume.getMaxZ() + 1));
if (periphery.contains(block)) { if (periphery.contains(block)) {
return true; return true;
} }

View File

@ -41,7 +41,7 @@ public class ZoneSetter {
warzone = new Warzone(this.player.getLocation().getWorld(), this.zoneName); warzone = new Warzone(this.player.getLocation().getWorld(), this.zoneName);
warzone.addAuthor(player.getName()); warzone.addAuthor(player.getName());
War.war.getIncompleteZones().add(warzone); War.war.getIncompleteZones().add(warzone);
warzone.getVolume().setNorthwest(northwestBlock); warzone.getVolume().setNorthwest(northwestBlock.getLocation());
War.war.msg(this.player, "Warzone " + warzone.getName() + " created. Northwesternmost point set to x:" + warzone.getVolume().getNorthwestX() + " z:" + warzone.getVolume().getNorthwestZ() + ". "); War.war.msg(this.player, "Warzone " + warzone.getName() + " created. Northwesternmost point set to x:" + warzone.getVolume().getNorthwestX() + " z:" + warzone.getVolume().getNorthwestZ() + ". ");
War.war.log(player.getName() + " created warzone " + zoneName + " by setting its nw corner", Level.INFO); War.war.log(player.getName() + " created warzone " + zoneName + " by setting its nw corner", Level.INFO);
} else if (!this.isPlayerAuthorOfZoneOrAdmin(warzone)) { } else if (!this.isPlayerAuthorOfZoneOrAdmin(warzone)) {
@ -49,7 +49,7 @@ public class ZoneSetter {
} else { } else {
// change existing warzone // change existing warzone
this.resetWarzone(warzone, msgString); this.resetWarzone(warzone, msgString);
warzone.getVolume().setNorthwest(northwestBlock); warzone.getVolume().setNorthwest(northwestBlock.getLocation());
msgString.append("Warzone " + warzone.getName() + " modified. Northwesternmost point set to x:" + warzone.getVolume().getNorthwestX() + " z:" + warzone.getVolume().getNorthwestZ() + ". "); msgString.append("Warzone " + warzone.getName() + " modified. Northwesternmost point set to x:" + warzone.getVolume().getNorthwestX() + " z:" + warzone.getVolume().getNorthwestZ() + ". ");
War.war.log(player.getName() + " updated warzone " + zoneName + " by setting its nw corner", Level.INFO); War.war.log(player.getName() + " updated warzone " + zoneName + " by setting its nw corner", Level.INFO);
} }
@ -86,7 +86,7 @@ public class ZoneSetter {
warzone = new Warzone(this.player.getLocation().getWorld(), this.zoneName); warzone = new Warzone(this.player.getLocation().getWorld(), this.zoneName);
warzone.addAuthor(player.getName()); warzone.addAuthor(player.getName());
War.war.getIncompleteZones().add(warzone); War.war.getIncompleteZones().add(warzone);
warzone.getVolume().setSoutheast(southeastBlock); warzone.getVolume().setSoutheast(southeastBlock.getLocation());
War.war.msg(this.player, "Warzone " + warzone.getName() + " created. Southeasternmost point set to x:" + warzone.getVolume().getSoutheastX() + " z:" + warzone.getVolume().getSoutheastZ() + ". "); War.war.msg(this.player, "Warzone " + warzone.getName() + " created. Southeasternmost point set to x:" + warzone.getVolume().getSoutheastX() + " z:" + warzone.getVolume().getSoutheastZ() + ". ");
War.war.log(player.getName() + " created warzone " + zoneName + " by setting its se corner", Level.INFO); War.war.log(player.getName() + " created warzone " + zoneName + " by setting its se corner", Level.INFO);
} else if (!this.isPlayerAuthorOfZoneOrAdmin(warzone)) { } else if (!this.isPlayerAuthorOfZoneOrAdmin(warzone)) {
@ -94,7 +94,7 @@ public class ZoneSetter {
} else { } else {
// change existing warzone // change existing warzone
this.resetWarzone(warzone, msgString); this.resetWarzone(warzone, msgString);
warzone.getVolume().setSoutheast(southeastBlock); warzone.getVolume().setSoutheast(southeastBlock.getLocation());
msgString.append("Warzone " + warzone.getName() + " modified. Southeasternmost point set to x:" + warzone.getVolume().getSoutheastX() + " z:" + warzone.getVolume().getSoutheastZ() + ". "); msgString.append("Warzone " + warzone.getName() + " modified. Southeasternmost point set to x:" + warzone.getVolume().getSoutheastX() + " z:" + warzone.getVolume().getSoutheastZ() + ". ");
War.war.log(player.getName() + " updated warzone " + zoneName + " by setting its se corner", Level.INFO); War.war.log(player.getName() + " updated warzone " + zoneName + " by setting its se corner", Level.INFO);
} }
@ -220,8 +220,8 @@ public class ZoneSetter {
if (warzone.getLobby() != null && warzone.getLobby().getVolume() != null) { if (warzone.getLobby() != null && warzone.getLobby().getVolume() != null) {
warzone.getLobby().getVolume().resetBlocks(); warzone.getLobby().getVolume().resetBlocks();
} }
int reset = warzone.getVolume().resetBlocks(); warzone.getVolume().resetBlocks();
msgString.append(reset + " blocks reset. "); msgString.append(warzone.getVolume().size() + " blocks reset. ");
} }
} }

View File

@ -7,27 +7,9 @@ import org.bukkit.inventory.ItemStack;
import com.tommytony.war.War; import com.tommytony.war.War;
@SuppressWarnings("deprecation")
public class LoadoutTxtMapper { public class LoadoutTxtMapper {
public static String fromLoadoutToString(HashMap<Integer, ItemStack> loadout) {
String loadoutString = "";
for (Integer slot : loadout.keySet()) {
ItemStack item = loadout.get(slot);
if (item != null) {
loadoutString += item.getTypeId() + "," + item.getAmount() + "," + slot + "," + item.getDurability() + "," + item.getData().getData();
if (item.getEnchantments().keySet().size() > 0) {
String enchantmentsStr = "";
for (Enchantment enchantment : item.getEnchantments().keySet()) {
enchantmentsStr += enchantment.getId() + ":" + item.getEnchantments().get(enchantment) + "::";
}
loadoutString += "," + enchantmentsStr;
}
}
loadoutString += ";";
}
return loadoutString;
}
public static void fromStringToLoadout(String loadoutString, HashMap<Integer, ItemStack> destinationLoadout) { public static void fromStringToLoadout(String loadoutString, HashMap<Integer, ItemStack> destinationLoadout) {
String[] rewardStrSplit = loadoutString.split(";"); String[] rewardStrSplit = loadoutString.split(";");
destinationLoadout.clear(); destinationLoadout.clear();

View File

@ -298,19 +298,19 @@ public class PreDeGaulleZoneVolumeMapper {
out.write("corner1"); out.write("corner1");
out.newLine(); out.newLine();
out.write(Integer.toString(volume.getCornerOne().getX())); out.write(Integer.toString(volume.getCornerOne().getBlockX()));
out.newLine(); out.newLine();
out.write(Integer.toString(volume.getCornerOne().getY())); out.write(Integer.toString(volume.getCornerOne().getBlockY()));
out.newLine(); out.newLine();
out.write(Integer.toString(volume.getCornerOne().getZ())); out.write(Integer.toString(volume.getCornerOne().getBlockZ()));
out.newLine(); out.newLine();
out.write("corner2"); out.write("corner2");
out.newLine(); out.newLine();
out.write(Integer.toString(volume.getCornerTwo().getX())); out.write(Integer.toString(volume.getCornerTwo().getBlockX()));
out.newLine(); out.newLine();
out.write(Integer.toString(volume.getCornerTwo().getY())); out.write(Integer.toString(volume.getCornerTwo().getBlockY()));
out.newLine(); out.newLine();
out.write(Integer.toString(volume.getCornerTwo().getZ())); out.write(Integer.toString(volume.getCornerTwo().getBlockZ()));
out.newLine(); out.newLine();
int x = 0; int x = 0;

View File

@ -152,19 +152,19 @@ public class VolumeMapper {
out.write("corner1"); out.write("corner1");
out.newLine(); out.newLine();
out.write(Integer.toString(volume.getCornerOne().getX())); out.write(Integer.toString(volume.getCornerOne().getBlockX()));
out.newLine(); out.newLine();
out.write(Integer.toString(volume.getCornerOne().getY())); out.write(Integer.toString(volume.getCornerOne().getBlockY()));
out.newLine(); out.newLine();
out.write(Integer.toString(volume.getCornerOne().getZ())); out.write(Integer.toString(volume.getCornerOne().getBlockZ()));
out.newLine(); out.newLine();
out.write("corner2"); out.write("corner2");
out.newLine(); out.newLine();
out.write(Integer.toString(volume.getCornerTwo().getX())); out.write(Integer.toString(volume.getCornerTwo().getBlockX()));
out.newLine(); out.newLine();
out.write(Integer.toString(volume.getCornerTwo().getY())); out.write(Integer.toString(volume.getCornerTwo().getBlockY()));
out.newLine(); out.newLine();
out.write(Integer.toString(volume.getCornerTwo().getZ())); out.write(Integer.toString(volume.getCornerTwo().getBlockZ()));
out.newLine(); out.newLine();
int blockWrites = 0; int blockWrites = 0;
for (int i = 0; i < volume.getSizeX(); i++) { for (int i = 0; i < volume.getSizeX(); i++) {

View File

@ -299,19 +299,19 @@ public class ZoneVolumeMapper {
cornersWriter.write("corner1"); cornersWriter.write("corner1");
cornersWriter.newLine(); cornersWriter.newLine();
cornersWriter.write(Integer.toString(volume.getCornerOne().getX())); cornersWriter.write(Integer.toString(volume.getCornerOne().getBlockX()));
cornersWriter.newLine(); cornersWriter.newLine();
cornersWriter.write(Integer.toString(volume.getCornerOne().getY())); cornersWriter.write(Integer.toString(volume.getCornerOne().getBlockY()));
cornersWriter.newLine(); cornersWriter.newLine();
cornersWriter.write(Integer.toString(volume.getCornerOne().getZ())); cornersWriter.write(Integer.toString(volume.getCornerOne().getBlockZ()));
cornersWriter.newLine(); cornersWriter.newLine();
cornersWriter.write("corner2"); cornersWriter.write("corner2");
cornersWriter.newLine(); cornersWriter.newLine();
cornersWriter.write(Integer.toString(volume.getCornerTwo().getX())); cornersWriter.write(Integer.toString(volume.getCornerTwo().getBlockX()));
cornersWriter.newLine(); cornersWriter.newLine();
cornersWriter.write(Integer.toString(volume.getCornerTwo().getY())); cornersWriter.write(Integer.toString(volume.getCornerTwo().getBlockY()));
cornersWriter.newLine(); cornersWriter.newLine();
cornersWriter.write(Integer.toString(volume.getCornerTwo().getZ())); cornersWriter.write(Integer.toString(volume.getCornerTwo().getBlockZ()));
cornersWriter.newLine(); cornersWriter.newLine();
int x = 0; int x = 0;

View File

@ -9,7 +9,6 @@ import org.bukkit.entity.Player;
import com.tommytony.war.Warzone; import com.tommytony.war.Warzone;
import com.tommytony.war.utility.Direction; import com.tommytony.war.utility.Direction;
import com.tommytony.war.volume.BlockInfo;
import com.tommytony.war.volume.Volume; import com.tommytony.war.volume.Volume;
/** /**
@ -35,19 +34,12 @@ public class Bomb {
public void addBombBlocks() { public void addBombBlocks() {
// make air (old two-high above floor) // make air (old two-high above floor)
Volume airGap = new Volume("airgap", this.warzone.getWorld()); Volume airGap = new Volume(new Location(this.volume.getWorld(),
airGap.setCornerOne(new BlockInfo( this.volume.getCornerOne().getX(), this.volume.getCornerOne()
this.volume.getCornerOne().getX(), .getY() + 1, this.volume.getCornerOne().getZ()),
this.volume.getCornerOne().getY() + 1, new Location(this.volume.getWorld(), this.volume.getCornerTwo()
this.volume.getCornerOne().getZ(), .getX(), this.volume.getCornerOne().getY() + 3,
0, this.volume.getCornerTwo().getZ()));
(byte)0));
airGap.setCornerTwo(new BlockInfo(
this.volume.getCornerTwo().getX(),
this.volume.getCornerOne().getY() + 3,
this.volume.getCornerTwo().getZ(),
0,
(byte)0));
airGap.setToMaterial(Material.AIR); airGap.setToMaterial(Material.AIR);
int x = this.location.getBlockX(); int x = this.location.getBlockX();

View File

@ -9,7 +9,6 @@ import org.bukkit.entity.Player;
import com.tommytony.war.Warzone; import com.tommytony.war.Warzone;
import com.tommytony.war.utility.Direction; import com.tommytony.war.utility.Direction;
import com.tommytony.war.volume.BlockInfo;
import com.tommytony.war.volume.Volume; import com.tommytony.war.volume.Volume;
/** /**
@ -35,19 +34,12 @@ public class Cake {
public void addCakeBlocks() { public void addCakeBlocks() {
// make air (old two-high above floor) // make air (old two-high above floor)
Volume airGap = new Volume("airgap", this.warzone.getWorld()); Volume airGap = new Volume(new Location(this.volume.getWorld(),
airGap.setCornerOne(new BlockInfo( this.volume.getCornerOne().getX(), this.volume.getCornerOne()
this.volume.getCornerOne().getX(), .getY() + 1, this.volume.getCornerOne().getZ()),
this.volume.getCornerOne().getY() + 1, new Location(this.volume.getWorld(), this.volume.getCornerTwo()
this.volume.getCornerOne().getZ(), .getX(), this.volume.getCornerOne().getY() + 2,
0, this.volume.getCornerTwo().getZ()));
(byte)0));
airGap.setCornerTwo(new BlockInfo(
this.volume.getCornerTwo().getX(),
this.volume.getCornerOne().getY() + 2,
this.volume.getCornerTwo().getZ(),
0,
(byte)0));
airGap.setToMaterial(Material.AIR); airGap.setToMaterial(Material.AIR);
int x = this.location.getBlockX(); int x = this.location.getBlockX();

View File

@ -10,7 +10,6 @@ import org.bukkit.material.MaterialData;
import com.tommytony.war.Team; import com.tommytony.war.Team;
import com.tommytony.war.Warzone; import com.tommytony.war.Warzone;
import com.tommytony.war.utility.Direction; import com.tommytony.war.utility.Direction;
import com.tommytony.war.volume.BlockInfo;
import com.tommytony.war.volume.Volume; import com.tommytony.war.volume.Volume;
/** /**
@ -36,19 +35,12 @@ public class Monument {
public void addMonumentBlocks() { public void addMonumentBlocks() {
// make air (old three-high above floor) // make air (old three-high above floor)
Volume airGap = new Volume("airgap", this.warzone.getWorld()); Volume airGap = new Volume(new Location(this.volume.getWorld(),
airGap.setCornerOne(new BlockInfo( this.volume.getCornerOne().getX(), this.volume.getCornerOne()
this.volume.getCornerOne().getX(), .getY() + 1, this.volume.getCornerOne().getZ()),
this.volume.getCornerOne().getY() + 1, new Location(this.volume.getWorld(), this.volume.getCornerTwo()
this.volume.getCornerOne().getZ(), .getX(), this.volume.getCornerOne().getY() + 3,
0, this.volume.getCornerTwo().getZ()));
(byte)0));
airGap.setCornerTwo(new BlockInfo(
this.volume.getCornerTwo().getX(),
this.volume.getCornerOne().getY() + 3,
this.volume.getCornerTwo().getZ(),
0,
(byte)0));
airGap.setToMaterial(Material.AIR); airGap.setToMaterial(Material.AIR);
this.ownerTeam = null; this.ownerTeam = null;

View File

@ -18,7 +18,6 @@ import com.tommytony.war.Warzone;
import com.tommytony.war.config.TeamConfig; import com.tommytony.war.config.TeamConfig;
import com.tommytony.war.config.WarzoneConfig; import com.tommytony.war.config.WarzoneConfig;
import com.tommytony.war.utility.Direction; import com.tommytony.war.utility.Direction;
import com.tommytony.war.volume.BlockInfo;
import com.tommytony.war.volume.Volume; import com.tommytony.war.volume.Volume;
/** /**
@ -171,7 +170,7 @@ public class WarHub {
warhubTpVolume.setToMaterial(Material.AIR); warhubTpVolume.setToMaterial(Material.AIR);
// draw gates // draw gates
Block currentGateBlock = BlockInfo.getBlock(this.location.getWorld(), this.volume.getCornerOne()).getRelative(BlockFace.UP).getRelative(front, hubDepth).getRelative(right, 2); Block currentGateBlock = this.volume.getCornerOne().getBlock().getRelative(BlockFace.UP).getRelative(front, hubDepth).getRelative(right, 2);
for (Warzone zone : War.war.getWarzones()) { // gonna use the index to find it again for (Warzone zone : War.war.getWarzones()) { // gonna use the index to find it again
if (!zone.getWarzoneConfig().getBoolean(WarzoneConfig.DISABLED)) { if (!zone.getWarzoneConfig().getBoolean(WarzoneConfig.DISABLED)) {

View File

@ -22,7 +22,6 @@ import com.tommytony.war.config.TeamConfig;
import com.tommytony.war.config.TeamKind; import com.tommytony.war.config.TeamKind;
import com.tommytony.war.config.WarzoneConfig; import com.tommytony.war.config.WarzoneConfig;
import com.tommytony.war.utility.Direction; import com.tommytony.war.utility.Direction;
import com.tommytony.war.volume.BlockInfo;
import com.tommytony.war.volume.Volume; import com.tommytony.war.volume.Volume;
import com.tommytony.war.volume.ZoneVolume; import com.tommytony.war.volume.ZoneVolume;
@ -35,14 +34,14 @@ public class ZoneLobby {
private final Warzone warzone; private final Warzone warzone;
private BlockFace wall; private BlockFace wall;
private Volume volume; private Volume volume;
BlockInfo lobbyMiddleWallBlock = null; // on the zone wall, one above the zone lobby floor Location lobbyMiddleWallBlock = null; // on the zone wall, one above the zone lobby floor
BlockInfo warHubLinkGate = null; Location warHubLinkGate = null;
Map<String, BlockInfo> teamGateBlocks = new HashMap<String, BlockInfo>(); Map<String, Location> teamGateBlocks = new HashMap<String, Location>();
BlockInfo autoAssignGate = null; Location autoAssignGate = null;
BlockInfo zoneTeleportBlock = null; Location zoneTeleportBlock = null;
private final int lobbyHeight = 3; private final int lobbyHeight = 3;
private int lobbyHalfSide; private int lobbyHalfSide;
@ -99,13 +98,13 @@ public class ZoneLobby {
// we're setting the zoneVolume directly, so we need to figure out the lobbyMiddleWallBlock on our own // we're setting the zoneVolume directly, so we need to figure out the lobbyMiddleWallBlock on our own
if (wall == Direction.NORTH()) { if (wall == Direction.NORTH()) {
this.lobbyMiddleWallBlock = new BlockInfo(BlockInfo.getBlock(warzone.getWorld(), volume.getCornerOne()).getRelative(BlockFace.UP).getRelative(Direction.EAST(), this.lobbyHalfSide)); this.lobbyMiddleWallBlock = volume.getCornerOne().getBlock().getRelative(BlockFace.UP).getRelative(Direction.EAST(), this.lobbyHalfSide).getLocation();
} else if (wall == Direction.EAST()) { } else if (wall == Direction.EAST()) {
this.lobbyMiddleWallBlock = new BlockInfo(BlockInfo.getBlock(warzone.getWorld(), volume.getCornerOne()).getRelative(BlockFace.UP).getRelative(Direction.SOUTH(), this.lobbyHalfSide)); this.lobbyMiddleWallBlock = volume.getCornerOne().getBlock().getRelative(BlockFace.UP).getRelative(Direction.SOUTH(), this.lobbyHalfSide).getLocation();
} else if (wall == Direction.SOUTH()) { } else if (wall == Direction.SOUTH()) {
this.lobbyMiddleWallBlock = new BlockInfo(BlockInfo.getBlock(warzone.getWorld(), volume.getCornerOne()).getRelative(BlockFace.UP).getRelative(Direction.WEST(), this.lobbyHalfSide)); this.lobbyMiddleWallBlock = volume.getCornerOne().getBlock().getRelative(BlockFace.UP).getRelative(Direction.WEST(), this.lobbyHalfSide).getLocation();
} else if (wall == Direction.WEST()) { } else if (wall == Direction.WEST()) {
this.lobbyMiddleWallBlock = new BlockInfo(BlockInfo.getBlock(warzone.getWorld(), volume.getCornerOne()).getRelative(BlockFace.UP).getRelative(Direction.NORTH(), this.lobbyHalfSide)); this.lobbyMiddleWallBlock = volume.getCornerOne().getBlock().getRelative(BlockFace.UP).getRelative(Direction.NORTH(), this.lobbyHalfSide).getLocation();
} }
} }
@ -157,13 +156,13 @@ public class ZoneLobby {
this.wall = opposite; // a player facing south places a lobby that looks just like a lobby stuck to the north wall this.wall = opposite; // a player facing south places a lobby that looks just like a lobby stuck to the north wall
this.calculateLobbyWidth(); this.calculateLobbyWidth();
this.lobbyMiddleWallBlock = new BlockInfo(lobbyWorld.getBlockAt(playerLocation.getBlockX(), playerLocation.getBlockY(), playerLocation.getBlockZ()).getRelative(facing, 6)); this.lobbyMiddleWallBlock = lobbyWorld.getBlockAt(playerLocation.getBlockX(), playerLocation.getBlockY(), playerLocation.getBlockZ()).getRelative(facing, 6).getLocation();
Block corner1 = null; Block corner1 = null;
Block corner2 = null; Block corner2 = null;
int x = this.lobbyMiddleWallBlock.getX(); int x = this.lobbyMiddleWallBlock.getBlockX();
int y = this.lobbyMiddleWallBlock.getY(); int y = this.lobbyMiddleWallBlock.getBlockY();
int z = this.lobbyMiddleWallBlock.getZ(); int z = this.lobbyMiddleWallBlock.getBlockZ();
if (this.wall == Direction.NORTH()) { if (this.wall == Direction.NORTH()) {
corner1 = lobbyWorld.getBlockAt(x, y - 1, z + this.lobbyHalfSide); corner1 = lobbyWorld.getBlockAt(x, y - 1, z + this.lobbyHalfSide);
@ -204,7 +203,7 @@ public class ZoneLobby {
int wallLength = wallEnd - wallStart + 1; int wallLength = wallEnd - wallStart + 1;
int wallCenterPos = wallStart + wallLength / 2; int wallCenterPos = wallStart + wallLength / 2;
int y = zoneVolume.getCenterY(); int y = zoneVolume.getCenterY();
this.lobbyMiddleWallBlock = new BlockInfo(this.warzone.getWorld().getBlockAt(x, y, wallCenterPos)); this.lobbyMiddleWallBlock = this.warzone.getWorld().getBlockAt(x, y, wallCenterPos).getLocation();
corner1 = this.warzone.getWorld().getBlockAt(x, y - 1, wallCenterPos + this.lobbyHalfSide); corner1 = this.warzone.getWorld().getBlockAt(x, y - 1, wallCenterPos + this.lobbyHalfSide);
corner2 = this.warzone.getWorld().getBlockAt(x - this.lobbyDepth, y + 1 + this.lobbyHeight, wallCenterPos - this.lobbyHalfSide); corner2 = this.warzone.getWorld().getBlockAt(x - this.lobbyDepth, y + 1 + this.lobbyHeight, wallCenterPos - this.lobbyHalfSide);
} else if (this.wall == Direction.EAST()) { } else if (this.wall == Direction.EAST()) {
@ -214,7 +213,7 @@ public class ZoneLobby {
int wallLength = wallEnd - wallStart + 1; int wallLength = wallEnd - wallStart + 1;
int wallCenterPos = wallStart + wallLength / 2; int wallCenterPos = wallStart + wallLength / 2;
int y = zoneVolume.getCenterY(); int y = zoneVolume.getCenterY();
this.lobbyMiddleWallBlock = new BlockInfo(this.warzone.getWorld().getBlockAt(wallCenterPos, y, z)); this.lobbyMiddleWallBlock = this.warzone.getWorld().getBlockAt(wallCenterPos, y, z).getLocation();
corner1 = this.warzone.getWorld().getBlockAt(wallCenterPos - this.lobbyHalfSide, y - 1, z); corner1 = this.warzone.getWorld().getBlockAt(wallCenterPos - this.lobbyHalfSide, y - 1, z);
corner2 = this.warzone.getWorld().getBlockAt(wallCenterPos + this.lobbyHalfSide, y + 1 + this.lobbyHeight, z - this.lobbyDepth); corner2 = this.warzone.getWorld().getBlockAt(wallCenterPos + this.lobbyHalfSide, y + 1 + this.lobbyHeight, z - this.lobbyDepth);
} else if (this.wall == Direction.SOUTH()) { } else if (this.wall == Direction.SOUTH()) {
@ -224,7 +223,7 @@ public class ZoneLobby {
int wallLength = wallEnd - wallStart + 1; int wallLength = wallEnd - wallStart + 1;
int wallCenterPos = wallStart + wallLength / 2; int wallCenterPos = wallStart + wallLength / 2;
int y = zoneVolume.getCenterY(); int y = zoneVolume.getCenterY();
this.lobbyMiddleWallBlock = new BlockInfo(this.warzone.getWorld().getBlockAt(x, y, wallCenterPos)); this.lobbyMiddleWallBlock = this.warzone.getWorld().getBlockAt(x, y, wallCenterPos).getLocation();
corner1 = this.warzone.getWorld().getBlockAt(x, y - 1, wallCenterPos - this.lobbyHalfSide); corner1 = this.warzone.getWorld().getBlockAt(x, y - 1, wallCenterPos - this.lobbyHalfSide);
corner2 = this.warzone.getWorld().getBlockAt(x + this.lobbyDepth, y + 1 + this.lobbyHeight, wallCenterPos + this.lobbyHalfSide); corner2 = this.warzone.getWorld().getBlockAt(x + this.lobbyDepth, y + 1 + this.lobbyHeight, wallCenterPos + this.lobbyHalfSide);
} else if (this.wall == Direction.WEST()) { } else if (this.wall == Direction.WEST()) {
@ -234,7 +233,7 @@ public class ZoneLobby {
int wallLength = wallEnd - wallStart + 1; int wallLength = wallEnd - wallStart + 1;
int wallCenterPos = wallStart + wallLength / 2; int wallCenterPos = wallStart + wallLength / 2;
int y = zoneVolume.getCenterY(); int y = zoneVolume.getCenterY();
this.lobbyMiddleWallBlock = new BlockInfo(this.warzone.getWorld().getBlockAt(wallCenterPos, y, z)); this.lobbyMiddleWallBlock = this.warzone.getWorld().getBlockAt(wallCenterPos, y, z).getLocation();
corner1 = this.warzone.getWorld().getBlockAt(wallCenterPos + this.lobbyHalfSide, y - 1, z); corner1 = this.warzone.getWorld().getBlockAt(wallCenterPos + this.lobbyHalfSide, y - 1, z);
corner2 = this.warzone.getWorld().getBlockAt(wallCenterPos - this.lobbyHalfSide, y + 1 + this.lobbyHeight, z + this.lobbyDepth); corner2 = this.warzone.getWorld().getBlockAt(wallCenterPos - this.lobbyHalfSide, y + 1 + this.lobbyHeight, z + this.lobbyDepth);
} }
@ -276,7 +275,7 @@ public class ZoneLobby {
public void initialize() { public void initialize() {
// maybe the number of teams change, now reset the gate positions // maybe the number of teams change, now reset the gate positions
if (this.lobbyMiddleWallBlock != null && this.volume != null) { if (this.lobbyMiddleWallBlock != null && this.volume != null) {
this.setGatePositions(BlockInfo.getBlock(this.volume.getWorld(), this.lobbyMiddleWallBlock)); this.setGatePositions(this.lobbyMiddleWallBlock.getBlock());
if (!warzone.getLobbyMaterials().getFloorBlock().getType().equals(Material.AIR)) { if (!warzone.getLobbyMaterials().getFloorBlock().getType().equals(Material.AIR)) {
// If air, leave original blocks. // If air, leave original blocks.
this.volume.setFaceMaterial(BlockFace.DOWN, warzone.getLobbyMaterials().getFloorBlock()); this.volume.setFaceMaterial(BlockFace.DOWN, warzone.getLobbyMaterials().getFloorBlock());
@ -289,7 +288,7 @@ public class ZoneLobby {
// add war hub link gate // add war hub link gate
if (War.war.getWarHub() != null) { if (War.war.getWarHub() != null) {
Block linkGateBlock = BlockInfo.getBlock(this.volume.getWorld(), this.warHubLinkGate); Block linkGateBlock = this.warHubLinkGate.getBlock();
this.placeWarhubLinkGate(linkGateBlock, warzone.getLobbyMaterials().getGateBlock()); this.placeWarhubLinkGate(linkGateBlock, warzone.getLobbyMaterials().getGateBlock());
// add warhub sign // add warhub sign
String[] lines = War.war.getString("sign.lobby.warhub").split("\n"); String[] lines = War.war.getString("sign.lobby.warhub").split("\n");
@ -299,15 +298,15 @@ public class ZoneLobby {
// add team gates or single auto assign gate // add team gates or single auto assign gate
this.placeAutoAssignGate(); this.placeAutoAssignGate();
for (String teamName : this.teamGateBlocks.keySet()) { for (String teamName : this.teamGateBlocks.keySet()) {
BlockInfo gateInfo = this.teamGateBlocks.get(teamName); Block gateInfo = this.teamGateBlocks.get(teamName).getBlock();
this.placeTeamGate(BlockInfo.getBlock(this.volume.getWorld(), gateInfo), TeamKind.teamKindFromString(teamName)); this.placeTeamGate(gateInfo, TeamKind.teamKindFromString(teamName));
} }
for (Team t : this.warzone.getTeams()) { for (Team t : this.warzone.getTeams()) {
this.resetTeamGateSign(t); this.resetTeamGateSign(t);
} }
// set zone tp // set zone tp
this.zoneTeleportBlock = new BlockInfo(BlockInfo.getBlock(this.volume.getWorld(), this.lobbyMiddleWallBlock).getRelative(this.wall, 6)); this.zoneTeleportBlock = this.lobbyMiddleWallBlock.getBlock().getRelative(this.wall, 6).getLocation();
int yaw = 0; int yaw = 0;
if (this.wall == Direction.WEST()) { if (this.wall == Direction.WEST()) {
yaw = 180; yaw = 180;
@ -339,7 +338,7 @@ public class ZoneLobby {
rightSide = Direction.SOUTH(); rightSide = Direction.SOUTH();
} }
Block clearedPathStartBlock = BlockInfo.getBlock(this.warzone.getWorld(), this.lobbyMiddleWallBlock).getRelative(this.wall, 2); Block clearedPathStartBlock = this.lobbyMiddleWallBlock.getBlock().getRelative(this.wall, 2);
Volume warzoneTeleportAir = new Volume("warzoneTeleport", clearedPathStartBlock.getWorld()); Volume warzoneTeleportAir = new Volume("warzoneTeleport", clearedPathStartBlock.getWorld());
warzoneTeleportAir.setCornerOne(clearedPathStartBlock.getRelative(leftSide)); warzoneTeleportAir.setCornerOne(clearedPathStartBlock.getRelative(leftSide));
warzoneTeleportAir.setCornerTwo(clearedPathStartBlock.getRelative(rightSide).getRelative(front, 4).getRelative(BlockFace.UP)); warzoneTeleportAir.setCornerTwo(clearedPathStartBlock.getRelative(rightSide).getRelative(front, 4).getRelative(BlockFace.UP));
@ -359,7 +358,7 @@ public class ZoneLobby {
clearedPathStartBlock.getRelative(this.wall).getRelative(this.wall).getRelative(this.wall).getRelative(this.wall).getRelative(this.wall).getRelative(BlockFace.UP).setType(Material.AIR); clearedPathStartBlock.getRelative(this.wall).getRelative(this.wall).getRelative(this.wall).getRelative(this.wall).getRelative(this.wall).getRelative(BlockFace.UP).setType(Material.AIR);
// set zone sign // set zone sign
Block zoneSignBlock = BlockInfo.getBlock(this.volume.getWorld(), this.lobbyMiddleWallBlock).getRelative(this.wall, 4); Block zoneSignBlock = this.lobbyMiddleWallBlock.getBlock().getRelative(this.wall, 4);
zoneSignBlock.setType(Material.SIGN_POST); zoneSignBlock.setType(Material.SIGN_POST);
org.bukkit.block.Sign block = (org.bukkit.block.Sign) zoneSignBlock.getState(); org.bukkit.block.Sign block = (org.bukkit.block.Sign) zoneSignBlock.getState();
org.bukkit.material.Sign data = (Sign) block.getData(); org.bukkit.material.Sign data = (Sign) block.getData();
@ -377,20 +376,20 @@ public class ZoneLobby {
block.update(true); block.update(true);
// lets get some light in here // lets get some light in here
if (this.wall == Direction.NORTH() || this.wall == Direction.SOUTH()) { if (this.wall == Direction.NORTH() || this.wall == Direction.SOUTH()) {
BlockState one = BlockInfo.getBlock(this.volume.getWorld(), this.lobbyMiddleWallBlock).getRelative(BlockFace.DOWN).getRelative(Direction.WEST(), this.lobbyHalfSide - 1).getRelative(this.wall, 9).getState(); BlockState one = this.lobbyMiddleWallBlock.getBlock().getRelative(BlockFace.DOWN).getRelative(Direction.WEST(), this.lobbyHalfSide - 1).getRelative(this.wall, 9).getState();
one.setType(warzone.getLobbyMaterials().getLightBlock().getType()); one.setType(warzone.getLobbyMaterials().getLightBlock().getType());
one.setData(warzone.getLobbyMaterials().getLightBlock().getData()); one.setData(warzone.getLobbyMaterials().getLightBlock().getData());
one.update(true); one.update(true);
one = BlockInfo.getBlock(this.volume.getWorld(), this.lobbyMiddleWallBlock).getRelative(BlockFace.DOWN).getRelative(Direction.EAST(), this.lobbyHalfSide - 1).getRelative(this.wall, 9).getState(); one = this.lobbyMiddleWallBlock.getBlock().getRelative(BlockFace.DOWN).getRelative(Direction.EAST(), this.lobbyHalfSide - 1).getRelative(this.wall, 9).getState();
one.setType(warzone.getLobbyMaterials().getLightBlock().getType()); one.setType(warzone.getLobbyMaterials().getLightBlock().getType());
one.setData(warzone.getLobbyMaterials().getLightBlock().getData()); one.setData(warzone.getLobbyMaterials().getLightBlock().getData());
one.update(true); one.update(true);
} else { } else {
BlockState one = BlockInfo.getBlock(this.volume.getWorld(), this.lobbyMiddleWallBlock).getRelative(BlockFace.DOWN).getRelative(Direction.NORTH(), this.lobbyHalfSide - 1).getRelative(this.wall, 9).getState(); BlockState one = this.lobbyMiddleWallBlock.getBlock().getRelative(BlockFace.DOWN).getRelative(Direction.NORTH(), this.lobbyHalfSide - 1).getRelative(this.wall, 9).getState();
one.setType(warzone.getLobbyMaterials().getLightBlock().getType()); one.setType(warzone.getLobbyMaterials().getLightBlock().getType());
one.setData(warzone.getLobbyMaterials().getLightBlock().getData()); one.setData(warzone.getLobbyMaterials().getLightBlock().getData());
one.update(true); one.update(true);
one = BlockInfo.getBlock(this.volume.getWorld(), this.lobbyMiddleWallBlock).getRelative(BlockFace.DOWN).getRelative(Direction.SOUTH(), this.lobbyHalfSide - 1).getRelative(this.wall, 9).getState(); one = this.lobbyMiddleWallBlock.getBlock().getRelative(BlockFace.DOWN).getRelative(Direction.SOUTH(), this.lobbyHalfSide - 1).getRelative(this.wall, 9).getState();
one.setType(warzone.getLobbyMaterials().getLightBlock().getType()); one.setType(warzone.getLobbyMaterials().getLightBlock().getType());
one.setData(warzone.getLobbyMaterials().getLightBlock().getData()); one.setData(warzone.getLobbyMaterials().getLightBlock().getData());
one.update(true); one.update(true);
@ -418,7 +417,7 @@ public class ZoneLobby {
} }
this.teamGateBlocks.clear(); this.teamGateBlocks.clear();
if (this.warzone.getWarzoneConfig().getBoolean(WarzoneConfig.AUTOASSIGN)) { if (this.warzone.getWarzoneConfig().getBoolean(WarzoneConfig.AUTOASSIGN)) {
this.autoAssignGate = new BlockInfo(lobbyMiddleWallBlock); this.autoAssignGate = lobbyMiddleWallBlock.getLocation();
} else { } else {
this.autoAssignGate = null; this.autoAssignGate = null;
for (int doorIndex = 0; doorIndex < this.warzone.getTeams().size(); doorIndex++) { for (int doorIndex = 0; doorIndex < this.warzone.getTeams().size(); doorIndex++) {
@ -427,23 +426,23 @@ public class ZoneLobby {
if (this.warzone.getTeams().size() % 2 == 0) { if (this.warzone.getTeams().size() % 2 == 0) {
// even number of teams // even number of teams
if (doorIndex % 2 == 0) { if (doorIndex % 2 == 0) {
this.teamGateBlocks.put(team.getName(), new BlockInfo(lobbyMiddleWallBlock.getRelative(rightSide, doorIndex * 2 + 2))); this.teamGateBlocks.put(team.getName(), lobbyMiddleWallBlock.getRelative(rightSide, doorIndex * 2 + 2).getLocation());
} else { } else {
this.teamGateBlocks.put(team.getName(), new BlockInfo(lobbyMiddleWallBlock.getRelative(leftSide, doorIndex * 2))); this.teamGateBlocks.put(team.getName(), lobbyMiddleWallBlock.getRelative(leftSide, doorIndex * 2).getLocation());
} }
} else { } else {
if (doorIndex == 0) { if (doorIndex == 0) {
this.teamGateBlocks.put(team.getName(), new BlockInfo(lobbyMiddleWallBlock)); this.teamGateBlocks.put(team.getName(), lobbyMiddleWallBlock.getLocation());
} else if (doorIndex % 2 == 0) { } else if (doorIndex % 2 == 0) {
this.teamGateBlocks.put(team.getName(), new BlockInfo(lobbyMiddleWallBlock.getRelative(rightSide, doorIndex * 2))); this.teamGateBlocks.put(team.getName(), lobbyMiddleWallBlock.getRelative(rightSide, doorIndex * 2).getLocation());
} else { } else {
this.teamGateBlocks.put(team.getName(), new BlockInfo(lobbyMiddleWallBlock.getRelative(leftSide, doorIndex * 2 + 2))); this.teamGateBlocks.put(team.getName(), lobbyMiddleWallBlock.getRelative(leftSide, doorIndex * 2 + 2).getLocation());
} }
} }
} }
} }
this.warHubLinkGate = new BlockInfo(lobbyMiddleWallBlock.getRelative(this.wall, 9)); this.warHubLinkGate = lobbyMiddleWallBlock.getRelative(this.wall, 9).getLocation();
} }
private void placeTeamGate(Block block, TeamKind teamKind) { private void placeTeamGate(Block block, TeamKind teamKind) {
@ -573,7 +572,7 @@ public class ZoneLobby {
List<Team> teams = this.warzone.getTeams(); List<Team> teams = this.warzone.getTeams();
Block autoAssignGateBlock = BlockInfo.getBlock(this.volume.getWorld(), this.autoAssignGate); Block autoAssignGateBlock = this.autoAssignGate.getBlock();
// minimal air path // minimal air path
this.clearGatePath(autoAssignGateBlock, front, leftSide, rightSide, false); this.clearGatePath(autoAssignGateBlock, front, leftSide, rightSide, false);
@ -601,7 +600,7 @@ public class ZoneLobby {
} }
public boolean isInTeamGate(Team team, Location location) { public boolean isInTeamGate(Team team, Location location) {
BlockInfo info = this.teamGateBlocks.get(team.getName()); Location info = this.teamGateBlocks.get(team.getName());
if (info != null) { if (info != null) {
if (location.getBlockX() == info.getX() && location.getBlockY() == info.getY() && location.getBlockZ() == info.getZ()) { if (location.getBlockX() == info.getX() && location.getBlockY() == info.getY() && location.getBlockZ() == info.getZ()) {
return true; return true;
@ -648,13 +647,13 @@ public class ZoneLobby {
public boolean blockIsAGateBlock(Block block, BlockFace blockWall) { public boolean blockIsAGateBlock(Block block, BlockFace blockWall) {
if (blockWall == this.wall) { if (blockWall == this.wall) {
for (String teamName : this.teamGateBlocks.keySet()) { for (String teamName : this.teamGateBlocks.keySet()) {
BlockInfo gateInfo = this.teamGateBlocks.get(teamName); Location gateInfo = this.teamGateBlocks.get(teamName);
if (this.isPartOfGate(BlockInfo.getBlock(this.volume.getWorld(), gateInfo), block)) { if (this.isPartOfGate(gateInfo.getBlock(), block)) {
return true; return true;
} }
} }
if (this.autoAssignGate != null && this.isPartOfGate(BlockInfo.getBlock(this.volume.getWorld(), this.autoAssignGate), block)) { if (this.autoAssignGate != null && this.isPartOfGate(this.autoAssignGate.getBlock(), block)) {
// auto assign // auto assign
return true; return true;
} }
@ -689,9 +688,9 @@ public class ZoneLobby {
} }
public void resetTeamGateSign(Team team) { public void resetTeamGateSign(Team team) {
BlockInfo info = this.teamGateBlocks.get(team.getName()); Location info = this.teamGateBlocks.get(team.getName());
if (info != null) { if (info != null) {
this.resetTeamGateSign(team, BlockInfo.getBlock(this.volume.getWorld(), info)); this.resetTeamGateSign(team, info.getBlock());
} }
} }
@ -783,14 +782,14 @@ public class ZoneLobby {
right = Direction.NORTH(); right = Direction.NORTH();
} }
if (this.autoAssignGate != null) { if (this.autoAssignGate != null) {
if (this.leaving(location, BlockInfo.getBlock(this.volume.getWorld(), this.autoAssignGate), inside, left, right)) { if (this.leaving(location, this.autoAssignGate.getBlock(), inside, left, right)) {
return true; return true;
} }
} }
for (String teamName : this.teamGateBlocks.keySet()) { for (String teamName : this.teamGateBlocks.keySet()) {
BlockInfo info = this.teamGateBlocks.get(teamName); Location info = this.teamGateBlocks.get(teamName);
if (this.leaving(location, BlockInfo.getBlock(this.volume.getWorld(), info), inside, left, right)) { if (this.leaving(location, info.getBlock(), inside, left, right)) {
return true; return true;
} }
} }

View File

@ -1,110 +0,0 @@
package com.tommytony.war.volume;
import org.bukkit.Material;
import org.bukkit.World;
import org.bukkit.block.Block;
/**
*
* @author tommytony
*
*/
public class BlockInfo {
private int x;
private int y;
private int z;
private int type;
private byte data;
// private String[] signLines;
public static Block getBlock(World world, BlockInfo info) {
return world.getBlockAt(info.getX(), info.getY(), info.getZ());
}
public BlockInfo(int x, int y, int z, int type, byte data) {
this.x = x;
this.y = y;
this.z = z;
this.type = type;
this.data = data;
}
public BlockInfo(Block block) {
this.x = block.getX();
this.y = block.getY();
this.z = block.getZ();
this.type = block.getTypeId();
this.data = block.getData();
// if (is(Material.SIGN) || is(Material.SIGN_POST)) {
// Sign sign = (Sign)block.getState();
// this.signLines = sign.getLines();
// }
}
// public BlockInfo(BlockState blockState) {
// this.x = blockState.getX();
// this.y = blockState.getY();
// this.z = blockState.getZ();
// this.type = blockState.getTypeId();
// this.data = blockState.getData().getData();
// // if (is(Material.SIGN) || is(Material.SIGN_POST)) {
// // Sign sign = (Sign)blockState;
// // this.signLines = sign.getLines();
// // }
// }
// public BlockInfo(int typeID, byte data, String[] lines) {
// type = typeID;
// this.data = data;
// //signLines = lines;
// }
public int getX() {
return this.x;
}
public int getY() {
return this.y;
}
public int getZ() {
return this.z;
}
// letting us mutate the BlockInfos might be a bad idea; use setters with care
public void setX(int x) {
this.x = x;
}
public void setY(int y) {
this.y = y;
}
public void setZ(int z) {
this.z = z;
}
public int getTypeId() {
return this.type;
}
public Material getType() {
return Material.getMaterial(this.type);
}
public byte getData() {
return this.data;
}
public boolean is(Material material) {
return this.getType() == material;
}
// public String[] getSignLines() {
// if (is(Material.SIGN) || is(Material.SIGN_POST)){
// return new String[4] {"", ""};
// }
// return null;
// }
}

View File

@ -1,171 +0,0 @@
package com.tommytony.war.volume;
import java.util.logging.Level;
import org.bukkit.Material;
import org.bukkit.World;
import org.bukkit.block.Block;
import org.bukkit.block.BlockFace;
import com.tommytony.war.War;
import com.tommytony.war.utility.Direction;
/**
*
* @author tommytony
*
*/
@Deprecated
public class VerticalVolume extends Volume {
public VerticalVolume(String name, World world) {
super(name, world);
}
@Override
public void setCornerOne(Block block) {
// corner one defaults to topmost corner
Block topBlock = this.getWorld().getBlockAt(block.getX(), 127, block.getZ());
super.setCornerOne(topBlock);
}
@Override
public void setCornerTwo(Block block) {
// corner two defaults to bottom most corner
Block bottomBlock = this.getWorld().getBlockAt(block.getX(), 0, block.getZ());
super.setCornerTwo(bottomBlock);
}
public boolean isWallBlock(Block block) {
return this.isEastWallBlock(block) || this.isNorthWallBlock(block) || this.isSouthWallBlock(block) || this.isWestWallBlock(block);
}
public boolean isEastWallBlock(Block block) {
if (this.getMinZ() == block.getZ() && block.getX() <= this.getMaxX() && block.getX() >= this.getMinX()) {
return true; // east wall
}
return false;
}
public boolean isSouthWallBlock(Block block) {
if (this.getMaxX() == block.getX() && block.getZ() <= this.getMaxZ() && block.getZ() >= this.getMinZ()) {
return true; // south wall
}
return false;
}
public boolean isNorthWallBlock(Block block) {
if (this.getMinX() == block.getX() && block.getZ() <= this.getMaxZ() && block.getZ() >= this.getMinZ()) {
return true; // north wall
}
return false;
}
public boolean isWestWallBlock(Block block) {
if (this.getMaxZ() == block.getZ() && block.getX() <= this.getMaxX() && block.getX() >= this.getMinX()) {
return true; // west wall
}
return false;
}
public int resetWallBlocks(BlockFace wall) {
int noOfResetBlocks = 0;
try {
if (this.hasTwoCorners() && this.getBlockTypes() != null) {
if (wall == Direction.EAST()) {
int z = this.getMinZ();
int k = 0;
int y = this.getMinY();
for (int j = 0; j < this.getSizeY(); j++) {
int x = this.getMinX();
for (int i = 0; i < this.getSizeX(); i++) {
int oldBlockType = this.getBlockTypes()[i][j][k];
byte oldBlockData = this.getBlockDatas()[i][j][k];
Block currentBlock = this.getWorld().getBlockAt(x, y, z);
if (this.resetBlock(oldBlockType, oldBlockData, currentBlock)) {
noOfResetBlocks++;
}
x++;
}
y++;
}
} else if (wall == Direction.WEST()) {
int z = this.getMaxZ();
int k = this.getSizeZ() - 1;
int y = this.getMinY();
for (int j = 0; j < this.getSizeY(); j++) {
int x = this.getMinX();
for (int i = 0; i < this.getSizeX(); i++) {
int oldBlockType = this.getBlockTypes()[i][j][k];
byte oldBlockData = this.getBlockDatas()[i][j][k];
Block currentBlock = this.getWorld().getBlockAt(x, y, z);
if (this.resetBlock(oldBlockType, oldBlockData, currentBlock)) {
noOfResetBlocks++;
}
x++;
}
y++;
}
} else if (wall == Direction.NORTH()) {
int x = this.getMinX();
int i = 0;
int y = this.getMinY();
for (int j = 0; j < this.getSizeY(); j++) {
int z = this.getMinZ();
for (int k = 0; k < this.getSizeZ(); k++) {
int oldBlockType = this.getBlockTypes()[i][j][k];
byte oldBlockData = this.getBlockDatas()[i][j][k];
Block currentBlock = this.getWorld().getBlockAt(x, y, z);
if (this.resetBlock(oldBlockType, oldBlockData, currentBlock)) {
noOfResetBlocks++;
}
z++;
}
y++;
}
} else if (wall == Direction.SOUTH()) {
int x = this.getMaxX();
int i = this.getSizeX() - 1;
int y = this.getMinY();
for (int j = 0; j < this.getSizeY(); j++) {
int z = this.getMinZ();
for (int k = 0; k < this.getSizeZ(); k++) {
int oldBlockType = this.getBlockTypes()[i][j][k];
byte oldBlockData = this.getBlockDatas()[i][j][k];
Block currentBlock = this.getWorld().getBlockAt(x, y, z);
if (this.resetBlock(oldBlockType, oldBlockData, currentBlock)) {
noOfResetBlocks++;
}
z++;
}
y++;
}
}
}
} catch (Exception e) {
War.war.log("Failed to reset wall " + wall + " in volume " + this.getName() + ". " + e.getClass().toString() + " " + e.getMessage(), Level.WARNING);
}
return noOfResetBlocks;
}
private boolean resetBlock(int oldBlockType, byte oldBlockData, Block currentBlock) {
if (currentBlock.getTypeId() != oldBlockType || (currentBlock.getTypeId() == oldBlockType && currentBlock.getData() != oldBlockData) || (currentBlock.getTypeId() == oldBlockType && currentBlock.getData() == oldBlockData && (oldBlockType == Material.WALL_SIGN.getId() || oldBlockType == Material.SIGN_POST.getId()))) {
currentBlock.setTypeId(oldBlockType);
currentBlock.setData(oldBlockData);
// if (oldBlockInfo.is(Material.SIGN) || oldBlockInfo.is(Material.SIGN_POST)) {
// BlockState state = currentBlock.getState();
// Sign currentSign = (Sign) state;
// currentSign.setLine(0, oldBlockInfo.getSignLines()[0]);
// currentSign.setLine(1, oldBlockInfo.getSignLines()[0]);
// currentSign.setLine(2, oldBlockInfo.getSignLines()[0]);
// currentSign.setLine(3, oldBlockInfo.getSignLines()[0]);
// state.update();
// }
return true;
}
return false;
}
}

View File

@ -31,12 +31,12 @@ import com.tommytony.war.utility.Direction;
public class Volume { public class Volume {
private String name; private String name;
private World world; private World world;
private BlockInfo cornerOne;
private BlockInfo cornerTwo;
private int[][][] blockTypes = null; private int[][][] blockTypes = null;
private byte[][][] blockDatas = null; private byte[][][] blockDatas = null;
private HashMap<String, String[]> signLines = new HashMap<String, String[]>(); private HashMap<String, String[]> signLines = new HashMap<String, String[]>();
private HashMap<String, List<ItemStack>> invBlockContents = new HashMap<String, List<ItemStack>>(); private HashMap<String, List<ItemStack>> invBlockContents = new HashMap<String, List<ItemStack>>();
private Location cornerOne;
private Location cornerTwo;
public Volume(String name, World world) { public Volume(String name, World world) {
this.name = name; this.name = name;
@ -50,8 +50,8 @@ public class Volume {
public Volume(Location corner1, Location corner2) { public Volume(Location corner1, Location corner2) {
this(corner1.getWorld()); this(corner1.getWorld());
Validate.isTrue(corner1.getWorld() == corner2.getWorld(), "Cross-world volume"); Validate.isTrue(corner1.getWorld() == corner2.getWorld(), "Cross-world volume");
this.cornerOne = new BlockInfo(corner1.getBlock()); this.cornerOne = corner1;
this.cornerTwo = new BlockInfo(corner2.getBlock()); this.cornerTwo = corner2;
} }
public void setName(String newName) { public void setName(String newName) {
@ -71,11 +71,11 @@ public class Volume {
} }
public void setCornerOne(Block block) { public void setCornerOne(Block block) {
this.cornerOne = new BlockInfo(block); this.cornerOne = block.getLocation();
} }
public void setCornerOne(BlockInfo blockInfo) { public void setCornerOne(Location location) {
this.cornerOne = blockInfo; this.cornerOne = location;
} }
public int saveBlocks() { public int saveBlocks() {
@ -314,28 +314,28 @@ public class Volume {
} }
public void setCornerTwo(Block block) { public void setCornerTwo(Block block) {
this.cornerTwo = new BlockInfo(block); this.cornerTwo = block.getLocation();
} }
public void setCornerTwo(BlockInfo blockInfo) { public void setCornerTwo(Location location) {
this.cornerTwo = blockInfo; this.cornerTwo = location;
} }
public BlockInfo getMinXBlock() { public Location getMinXBlock() {
if (this.cornerOne.getX() < this.cornerTwo.getX()) { if (this.cornerOne.getX() < this.cornerTwo.getX()) {
return this.cornerOne; return this.cornerOne;
} }
return this.cornerTwo; return this.cornerTwo;
} }
public BlockInfo getMinYBlock() { public Location getMinYBlock() {
if (this.cornerOne.getY() < this.cornerTwo.getY()) { if (this.cornerOne.getY() < this.cornerTwo.getY()) {
return this.cornerOne; return this.cornerOne;
} }
return this.cornerTwo; return this.cornerTwo;
} }
public BlockInfo getMinZBlock() { public Location getMinZBlock() {
if (this.cornerOne.getZ() < this.cornerTwo.getZ()) { if (this.cornerOne.getZ() < this.cornerTwo.getZ()) {
return this.cornerOne; return this.cornerOne;
} }
@ -343,32 +343,32 @@ public class Volume {
} }
public int getMinX() { public int getMinX() {
return this.getMinXBlock().getX(); return this.getMinXBlock().getBlockX();
} }
public int getMinY() { public int getMinY() {
return this.getMinYBlock().getY(); return this.getMinYBlock().getBlockY();
} }
public int getMinZ() { public int getMinZ() {
return this.getMinZBlock().getZ(); return this.getMinZBlock().getBlockZ();
} }
public BlockInfo getMaxXBlock() { public Location getMaxXBlock() {
if (this.cornerOne.getX() < this.cornerTwo.getX()) { if (this.cornerOne.getX() < this.cornerTwo.getX()) {
return this.cornerTwo; return this.cornerTwo;
} }
return this.cornerOne; return this.cornerOne;
} }
public BlockInfo getMaxYBlock() { public Location getMaxYBlock() {
if (this.cornerOne.getY() < this.cornerTwo.getY()) { if (this.cornerOne.getY() < this.cornerTwo.getY()) {
return this.cornerTwo; return this.cornerTwo;
} }
return this.cornerOne; return this.cornerOne;
} }
public BlockInfo getMaxZBlock() { public Location getMaxZBlock() {
if (this.cornerOne.getZ() < this.cornerTwo.getZ()) { if (this.cornerOne.getZ() < this.cornerTwo.getZ()) {
return this.cornerTwo; return this.cornerTwo;
} }
@ -376,15 +376,15 @@ public class Volume {
} }
public int getMaxX() { public int getMaxX() {
return this.getMaxXBlock().getX(); return this.getMaxXBlock().getBlockX();
} }
public int getMaxY() { public int getMaxY() {
return this.getMaxYBlock().getY(); return this.getMaxYBlock().getBlockY();
} }
public int getMaxZ() { public int getMaxZ() {
return this.getMaxZBlock().getZ(); return this.getMaxZBlock().getBlockZ();
} }
public int getSizeX() { public int getSizeX() {
@ -407,11 +407,11 @@ public class Volume {
return this.blockTypes; return this.blockTypes;
} }
public BlockInfo getCornerOne() { public Location getCornerOne() {
return this.cornerOne; return this.cornerOne;
} }
public BlockInfo getCornerTwo() { public Location getCornerTwo() {
return this.cornerTwo; return this.cornerTwo;
} }
@ -557,4 +557,8 @@ public class Volume {
this.invBlockContents.clear(); this.invBlockContents.clear();
this.invBlockContents = null; this.invBlockContents = null;
} }
public int size() {
return this.getSizeX() * this.getSizeY() * this.getSizeZ();
}
} }

View File

@ -1,5 +1,6 @@
package com.tommytony.war.volume; package com.tommytony.war.volume;
import org.bukkit.Location;
import org.bukkit.World; import org.bukkit.World;
import org.bukkit.block.Block; import org.bukkit.block.Block;
@ -63,11 +64,11 @@ public class ZoneVolume extends Volume {
return; return;
} }
public void setNorthwest(Block block) throws NotNorthwestException, TooSmallException, TooBigException { public void setNorthwest(Location block) throws NotNorthwestException, TooSmallException, TooBigException {
// northwest defaults to top block // northwest defaults to top block
BlockInfo topBlock = new BlockInfo(block.getX(), 127, block.getZ(), block.getTypeId(), block.getData()); Location topBlock = new Location(block.getWorld(), block.getX(), block.getWorld().getMaxHeight(), block.getZ());
BlockInfo oldCornerOne = this.getCornerOne(); Location oldCornerOne = this.getCornerOne();
BlockInfo oldCornerTwo = this.getCornerTwo(); Location oldCornerTwo = this.getCornerTwo();
if (this.getCornerOne() == null) { if (this.getCornerOne() == null) {
if (this.getCornerTwo() == null) { if (this.getCornerTwo() == null) {
// northwest defaults to corner 1 // northwest defaults to corner 1
@ -89,10 +90,8 @@ public class ZoneVolume extends Volume {
if (this.getSoutheastX() <= block.getX() || this.getSoutheastZ() >= block.getZ()) { if (this.getSoutheastX() <= block.getX() || this.getSoutheastZ() >= block.getZ()) {
throw new NotNorthwestException(); throw new NotNorthwestException();
} }
BlockInfo minXBlock = this.getMinXBlock(); // north means min X this.getMinXBlock().setX(block.getX()); // north means min X
minXBlock.setX(block.getX()); // mutating, argh! this.getMaxZBlock().setZ(block.getZ()); // west means max Z
BlockInfo maxZBlock = this.getMaxZBlock(); // west means max Z
maxZBlock.setZ(block.getZ());
} }
if (this.tooSmall() || this.zoneStructuresAreOutside()) { if (this.tooSmall() || this.zoneStructuresAreOutside()) {
super.setCornerOne(oldCornerOne); super.setCornerOne(oldCornerOne);
@ -121,11 +120,11 @@ public class ZoneVolume extends Volume {
} }
} }
public void setSoutheast(Block block) throws NotSoutheastException, TooSmallException, TooBigException { public void setSoutheast(Location block) throws NotSoutheastException, TooSmallException, TooBigException {
// southeast defaults to bottom block // southeast defaults to bottom block
BlockInfo bottomBlock = new BlockInfo(block.getX(), 0, block.getZ(), block.getTypeId(), block.getData()); Location bottomBlock = new Location(block.getWorld(), block.getX(), 0, block.getZ());
BlockInfo oldCornerOne = this.getCornerOne(); Location oldCornerOne = this.getCornerOne();
BlockInfo oldCornerTwo = this.getCornerTwo(); Location oldCornerTwo = this.getCornerTwo();
if (this.getCornerTwo() == null) { if (this.getCornerTwo() == null) {
if (this.getCornerOne() == null) { if (this.getCornerOne() == null) {
// southeast defaults to corner 2 // southeast defaults to corner 2
@ -147,10 +146,8 @@ public class ZoneVolume extends Volume {
if (this.getNorthwestX() >= block.getX() || this.getNorthwestZ() <= block.getZ()) { if (this.getNorthwestX() >= block.getX() || this.getNorthwestZ() <= block.getZ()) {
throw new NotSoutheastException(); throw new NotSoutheastException();
} }
BlockInfo maxXBlock = this.getMaxXBlock(); // south means max X this.getMaxXBlock().setX(block.getX()); // south means max X
maxXBlock.setX(block.getX()); // mutating, argh! this.getMinZBlock().setZ(block.getZ()); // east means min Z
BlockInfo minZBlock = this.getMinZBlock(); // east means min Z
minZBlock.setZ(block.getZ());
} }
if (this.tooSmall() || this.zoneStructuresAreOutside()) { if (this.tooSmall() || this.zoneStructuresAreOutside()) {
super.setCornerOne(oldCornerOne); super.setCornerOne(oldCornerOne);
@ -189,7 +186,7 @@ public class ZoneVolume extends Volume {
} }
public void setZoneCornerOne(Block block) throws TooSmallException, TooBigException { public void setZoneCornerOne(Block block) throws TooSmallException, TooBigException {
BlockInfo oldCornerOne = this.getCornerOne(); Location oldCornerOne = this.getCornerOne();
super.setCornerOne(block); super.setCornerOne(block);
if (this.tooSmall() || this.zoneStructuresAreOutside()) { if (this.tooSmall() || this.zoneStructuresAreOutside()) {
super.setCornerOne(oldCornerOne); super.setCornerOne(oldCornerOne);
@ -201,7 +198,7 @@ public class ZoneVolume extends Volume {
} }
public void setZoneCornerTwo(Block block) throws TooSmallException, TooBigException { public void setZoneCornerTwo(Block block) throws TooSmallException, TooBigException {
BlockInfo oldCornerTwo = this.getCornerTwo(); Location oldCornerTwo = this.getCornerTwo();
super.setCornerTwo(block); super.setCornerTwo(block);
if (this.tooSmall() || this.zoneStructuresAreOutside()) { if (this.tooSmall() || this.zoneStructuresAreOutside()) {
super.setCornerTwo(oldCornerTwo); super.setCornerTwo(oldCornerTwo);
@ -251,8 +248,8 @@ public class ZoneVolume extends Volume {
return false; return false;
} }
private boolean isInside(BlockInfo info) { private boolean isInside(Location location) {
if (info.getX() <= this.getMaxX() && info.getX() >= this.getMinX() && info.getY() <= this.getMaxY() && info.getY() >= this.getMinY() && info.getZ() <= this.getMaxZ() && info.getZ() >= this.getMinZ()) { if (location.getX() <= this.getMaxX() && location.getX() >= this.getMinX() && location.getY() <= this.getMaxY() && location.getY() >= this.getMinY() && location.getZ() <= this.getMaxZ() && location.getZ() >= this.getMinZ()) {
return true; return true;
} }
return false; return false;

View File

@ -1,52 +1,52 @@
package com.tommytony.war.spec.volumes; package com.tommytony.war.spec.volumes;
import static org.junit.Assert.assertEquals;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.when;
import java.util.ArrayList; import java.util.ArrayList;
import org.bukkit.Location;
import org.bukkit.World; import org.bukkit.World;
import org.bukkit.block.Block;
import org.junit.Test; import org.junit.Test;
import static org.junit.Assert.*; import com.tommytony.war.Team;
import static org.mockito.Mockito.*; import com.tommytony.war.Warzone;
import com.tommytony.war.*;
import com.tommytony.war.structure.Monument; import com.tommytony.war.structure.Monument;
import com.tommytony.war.volume.*; import com.tommytony.war.volume.NotNorthwestException;
import com.tommytony.war.volume.NotSoutheastException;
import com.tommytony.war.volume.TooBigException;
import com.tommytony.war.volume.TooSmallException;
import com.tommytony.war.volume.ZoneVolume;
public class ZoneVolumeSpecTest { public class ZoneVolumeSpecTest {
// setNorthwest // setNorthwest
@Test @Test
public void setNorthwest_whenCreatingAndNoCornersAreSet_shouldSetCorner1AtTop() throws NotNorthwestException, TooSmallException, TooBigException{ public void setNorthwest_whenCreatingAndNoCornersAreSet_shouldSetCorner1AtTop()
throws NotNorthwestException, TooSmallException, TooBigException {
// Arrange // Arrange
World worldMock = mock(World.class); World worldMock = mock(World.class);
when(worldMock.getMaxHeight()).thenReturn(256);
Warzone zoneMock = mock(Warzone.class); Warzone zoneMock = mock(Warzone.class);
when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>()); when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>());
when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>()); when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>());
ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock); ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock);
Block blockMock = mock(Block.class); Location nw = new Location(worldMock, 0, 64, 0);
when(blockMock.getX()).thenReturn(0);
when(blockMock.getY()).thenReturn(64); // at sea level
when(blockMock.getZ()).thenReturn(0);
when(blockMock.getTypeId()).thenReturn(10);
when(blockMock.getData()).thenReturn((byte)2);
// Act // Act
volume.setNorthwest(blockMock); volume.setNorthwest(nw);
// Assert // Assert
assertEquals(null, volume.getCornerTwo()); Location movedOne = new Location(worldMock, 0, 256, 0);
assertEquals(0, volume.getCornerOne().getX()); assertEquals(movedOne, volume.getCornerOne());
assertEquals(127, volume.getCornerOne().getY()); // the corner should shoot up to the top
assertEquals(0, volume.getCornerOne().getZ());
assertEquals(10, volume.getCornerOne().getTypeId());
assertEquals((byte)2, volume.getCornerOne().getData());
} }
@Test @Test(expected = NotNorthwestException.class)
public void setNorthwest_whenCreating_AndNoCorner1IsSet_ButCorner2Set_AndNewCornerBlockIsToEastOfCorner2_shouldThrowNotNorthwestException() throws TooSmallException, TooBigException{ public void setNorthwest_whenCreating_AndNoCorner1IsSet_ButCorner2Set_AndNewCornerBlockIsToEastOfCorner2_shouldThrowNotNorthwestException()
throws TooSmallException, TooBigException, NotNorthwestException {
// Arrange // Arrange
World worldMock = mock(World.class); World worldMock = mock(World.class);
@ -54,33 +54,17 @@ public class ZoneVolumeSpecTest {
when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>()); when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>());
when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>()); when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>());
ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock); ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock);
Block blockMock = mock(Block.class); Location nw = new Location(worldMock, -64, 64, -64);
when(blockMock.getX()).thenReturn(-64); // further north
when(blockMock.getY()).thenReturn(64); // at sea level
when(blockMock.getZ()).thenReturn(-64); // further east
when(blockMock.getTypeId()).thenReturn(10);
when(blockMock.getData()).thenReturn((byte)2);
// Act // Act
BlockInfo existingCorner2 = new BlockInfo(0, 64, 0, 4, (byte)4); Location existingCorner2 = new Location(worldMock, 0, 64, 0);
volume.setCornerTwo(existingCorner2); // corner 2 already set volume.setCornerTwo(existingCorner2); // corner 2 already set
boolean failed = false; volume.setNorthwest(nw);
try {
volume.setNorthwest(blockMock);
}
catch(NotNorthwestException e) {
failed = true;
} }
// Assert @Test(expected = NotNorthwestException.class)
// first corner shouldn't move public void setNorthwest_whenCreating_AndNoCorner1IsSet_ButCorner2Set_AndNewCornerBlockIsToSouthOfCorner2_shouldThrowNotNorthwestException()
assertTrue(failed); throws TooSmallException, TooBigException, NotNorthwestException {
assertEquals(null, volume.getCornerOne());
assertEquals(existingCorner2, volume.getCornerTwo());
}
@Test
public void setNorthwest_whenCreating_AndNoCorner1IsSet_ButCorner2Set_AndNewCornerBlockIsToSouthOfCorner2_shouldThrowNotNorthwestException() throws TooSmallException, TooBigException{
// Arrange // Arrange
World worldMock = mock(World.class); World worldMock = mock(World.class);
@ -88,33 +72,17 @@ public class ZoneVolumeSpecTest {
when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>()); when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>());
when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>()); when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>());
ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock); ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock);
Block blockMock = mock(Block.class); Location nw = new Location(worldMock, 64, 64, 64);
when(blockMock.getX()).thenReturn(64); // further south
when(blockMock.getY()).thenReturn(64); // at sea level
when(blockMock.getZ()).thenReturn(64); // further west
when(blockMock.getTypeId()).thenReturn(10);
when(blockMock.getData()).thenReturn((byte)2);
// Act // Act
BlockInfo existingCorner2 = new BlockInfo(0, 64, 0, 4, (byte)4); Location existingCorner2 = new Location(worldMock, 0, 64, 0);
volume.setCornerTwo(existingCorner2); // corner 2 already set volume.setCornerTwo(existingCorner2); // corner 2 already set
boolean failed = false; volume.setNorthwest(nw);
try {
volume.setNorthwest(blockMock);
}
catch(NotNorthwestException e) {
failed = true;
} }
// Assert @Test(expected = TooSmallException.class)
// first corner shouldn't move public void setNorthwest_whenCreating_AndNoCorner1IsSet_ButCorner2Set_AndNewCornerBlockIsTooCloseToCorner2_shouldThrowTooSmallException()
assertTrue(failed); throws NotNorthwestException, TooBigException, TooSmallException {
assertEquals(null, volume.getCornerOne());
assertEquals(existingCorner2, volume.getCornerTwo());
}
@Test
public void setNorthwest_whenCreating_AndNoCorner1IsSet_ButCorner2Set_AndNewCornerBlockIsTooCloseToCorner2_shouldThrowTooSmallException() throws NotNorthwestException, TooBigException{
// Arrange // Arrange
World worldMock = mock(World.class); World worldMock = mock(World.class);
@ -122,33 +90,17 @@ public class ZoneVolumeSpecTest {
when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>()); when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>());
when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>()); when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>());
ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock); ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock);
Block blockMock = mock(Block.class); Location nw = new Location(worldMock, -5, 64, 5);
when(blockMock.getX()).thenReturn(-5); // further south
when(blockMock.getY()).thenReturn(64); // at sea level
when(blockMock.getZ()).thenReturn(5); // further west
when(blockMock.getTypeId()).thenReturn(10);
when(blockMock.getData()).thenReturn((byte)2);
// Act // Act
BlockInfo existingCorner2 = new BlockInfo(0, 64, 0, 4, (byte)4); Location existingCorner2 = new Location(worldMock, 0, 64, 0);
volume.setCornerTwo(existingCorner2); // corner 2 already set volume.setCornerTwo(existingCorner2); // corner 2 already set
boolean failed = false; volume.setNorthwest(nw);
try {
volume.setNorthwest(blockMock);
}
catch(TooSmallException e) {
failed = true;
} }
// Assert @Test(expected = TooBigException.class)
// first corner shouldn't move public void setNorthwest_whenCreating_AndNoCorner1IsSet_ButCorner2Set_AndNewCornerBlockIsTooFarFromCorner2_shouldThrowTooBigException()
assertTrue(failed); throws NotNorthwestException, TooSmallException, TooBigException {
assertEquals(null, volume.getCornerOne());
assertEquals(existingCorner2, volume.getCornerTwo());
}
@Test
public void setNorthwest_whenCreating_AndNoCorner1IsSet_ButCorner2Set_AndNewCornerBlockIsTooFarFromCorner2_shouldThrowTooBigException() throws NotNorthwestException, TooSmallException{
// Arrange // Arrange
World worldMock = mock(World.class); World worldMock = mock(World.class);
@ -156,103 +108,43 @@ public class ZoneVolumeSpecTest {
when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>()); when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>());
when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>()); when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>());
ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock); ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock);
Block blockMock = mock(Block.class); Location nw = new Location(worldMock, -1000, 64, 1000);
when(blockMock.getX()).thenReturn(-1000); // further south
when(blockMock.getY()).thenReturn(64); // at sea level
when(blockMock.getZ()).thenReturn(1000); // further west
when(blockMock.getTypeId()).thenReturn(10);
when(blockMock.getData()).thenReturn((byte)2);
// Act // Act
BlockInfo existingCorner2 = new BlockInfo(0, 64, 0, 4, (byte)4); Location existingCorner2 = new Location(worldMock, 0, 64, 0);
volume.setCornerTwo(existingCorner2); // corner 2 already set volume.setCornerTwo(existingCorner2); // corner 2 already set
boolean failed = false; volume.setNorthwest(nw);
try {
volume.setNorthwest(blockMock);
}
catch(TooBigException e) {
failed = true;
}
// Assert
// first corner shouldn't move
assertTrue(failed);
assertEquals(null, volume.getCornerOne());
assertEquals(existingCorner2, volume.getCornerTwo());
} }
@Test @Test
public void setNorthwest_whenCreatingAndCorner1AlreadySet_shouldSetCorner2AtTop() throws NotNorthwestException, TooSmallException, TooBigException{ // nw always goes to top public void setNorthwest_whenCreatingAndCorner1AlreadySet_shouldSetCorner2AtTop()
throws NotNorthwestException, TooSmallException, TooBigException {
// Arrange // Arrange
World worldMock = mock(World.class); World worldMock = mock(World.class);
when(worldMock.getMaxHeight()).thenReturn(256);
Warzone zoneMock = mock(Warzone.class); Warzone zoneMock = mock(Warzone.class);
when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>()); when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>());
when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>()); when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>());
ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock); ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock);
Block blockMock = mock(Block.class); Location nw = new Location(worldMock, -64, 64, 64);
when(blockMock.getX()).thenReturn(-64); // further north
when(blockMock.getY()).thenReturn(64); // at sea level
when(blockMock.getZ()).thenReturn(64); // further west
when(blockMock.getTypeId()).thenReturn(10);
when(blockMock.getData()).thenReturn((byte)2);
// Act // Act
BlockInfo existingCorner1 = new BlockInfo(0, 64, 0, 4, (byte)4); Location existingCorner1 = new Location(worldMock, 0, 64, 0);
volume.setCornerOne(existingCorner1); // corner 1 already set volume.setCornerOne(existingCorner1); // corner 1 already set
volume.setNorthwest(blockMock); volume.setNorthwest(nw);
// Assert // Assert
// first corner shouldn't move // first corner shouldn't move
assertEquals(0, volume.getCornerOne().getX());
assertEquals(64, volume.getCornerOne().getY());
assertEquals(0, volume.getCornerOne().getZ());
assertEquals(4, volume.getCornerOne().getTypeId());
assertEquals((byte)4, volume.getCornerOne().getData());
assertEquals(-64, volume.getCornerTwo().getX());
assertEquals(127, volume.getCornerTwo().getY()); // the new corner should shoot up to the top
assertEquals(64, volume.getCornerTwo().getZ());
assertEquals(10, volume.getCornerTwo().getTypeId());
assertEquals((byte)2, volume.getCornerTwo().getData());
}
@Test
public void setNorthwest_whenCreating_AndCorner1AlreadySet_ButNewCornerBlockIsEastOfCorner1_shouldThrowNotNorthwestException() throws TooSmallException, TooBigException{
// Arrange
World worldMock = mock(World.class);
Warzone zoneMock = mock(Warzone.class);
when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>());
when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>());
ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock);
Block blockMock = mock(Block.class);
when(blockMock.getX()).thenReturn(-64); // further north
when(blockMock.getY()).thenReturn(64); // at sea level
when(blockMock.getZ()).thenReturn(-64); // further east
when(blockMock.getTypeId()).thenReturn(10);
when(blockMock.getData()).thenReturn((byte)2);
// Act
BlockInfo existingCorner1 = new BlockInfo(0, 64, 0, 4, (byte)4);
volume.setCornerOne(existingCorner1); // corner 1 already set
boolean failed = false;
try {
volume.setNorthwest(blockMock);
}
catch(NotNorthwestException e) {
failed = true;
}
// Assert
// first corner shouldn't move
assertTrue(failed);
assertEquals(null, volume.getCornerTwo());
assertEquals(existingCorner1, volume.getCornerOne()); assertEquals(existingCorner1, volume.getCornerOne());
Location nwMax = new Location(worldMock, -64, 256, 64);
assertEquals(nwMax, volume.getCornerTwo());
} }
@Test @Test(expected = NotNorthwestException.class)
public void setNorthwest_whenCreating_AndCorner1AlreadySet_ButNewCornerBlockIsSouthOfCorner1_shouldThrowNotNorthwestException() throws TooSmallException, TooBigException{ public void setNorthwest_whenCreating_AndCorner1AlreadySet_ButNewCornerBlockIsEastOfCorner1_shouldThrowNotNorthwestException()
throws TooSmallException, TooBigException, NotNorthwestException {
// Arrange // Arrange
World worldMock = mock(World.class); World worldMock = mock(World.class);
@ -260,33 +152,17 @@ public class ZoneVolumeSpecTest {
when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>()); when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>());
when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>()); when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>());
ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock); ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock);
Block blockMock = mock(Block.class); Location nw = new Location(worldMock, -64, 64, -64);
when(blockMock.getX()).thenReturn(64); // further south
when(blockMock.getY()).thenReturn(64); // at sea level
when(blockMock.getZ()).thenReturn(64); // further west
when(blockMock.getTypeId()).thenReturn(10);
when(blockMock.getData()).thenReturn((byte)2);
// Act // Act
BlockInfo existingCorner1 = new BlockInfo(0, 64, 0, 4, (byte)4); Location existingCorner1 = new Location(worldMock, 0, 64, 0);
volume.setCornerOne(existingCorner1); // corner 1 already set volume.setCornerOne(existingCorner1); // corner 1 already set
boolean failed = false; volume.setNorthwest(nw);
try {
volume.setNorthwest(blockMock);
}
catch(NotNorthwestException e) {
failed = true;
} }
// Assert @Test(expected = NotNorthwestException.class)
// first corner shouldn't move public void setNorthwest_whenCreating_AndCorner1AlreadySet_ButNewCornerBlockIsSouthOfCorner1_shouldThrowNotNorthwestException()
assertTrue(failed); throws TooSmallException, TooBigException, NotNorthwestException {
assertEquals(null, volume.getCornerTwo());
assertEquals(existingCorner1, volume.getCornerOne());
}
@Test
public void setNorthwest_whenChangingVolumeWithCorner1NwCorner2Se_shouldMoveCorner1() throws NotNorthwestException, TooSmallException, TooBigException{
// Arrange // Arrange
World worldMock = mock(World.class); World worldMock = mock(World.class);
@ -294,38 +170,45 @@ public class ZoneVolumeSpecTest {
when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>()); when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>());
when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>()); when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>());
ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock); ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock);
Block blockMock = mock(Block.class); Location nw = new Location(worldMock, 64, 64, 64);
when(blockMock.getX()).thenReturn(-64); // further north
when(blockMock.getY()).thenReturn(64); // at sea level
when(blockMock.getZ()).thenReturn(64); // further west
when(blockMock.getTypeId()).thenReturn(10);
when(blockMock.getData()).thenReturn((byte)2);
// Act // Act
BlockInfo existingCorner1 = new BlockInfo(-32, 32, 32, 2, (byte)2); // corner 1 at minX and maxZ (nw) Location existingCorner1 = new Location(worldMock, 0, 64, 0);
volume.setCornerOne(existingCorner1); // corner 1 already set volume.setCornerOne(existingCorner1); // corner 1 already set
BlockInfo existingCorner2 = new BlockInfo(32, 96, -32, 4, (byte)4); // corner 2 at maxX and minZ (se) volume.setNorthwest(nw);
}
@Test
public void setNorthwest_whenChangingVolumeWithCorner1NwCorner2Se_shouldMoveCorner1()
throws NotNorthwestException, TooSmallException, TooBigException {
// Arrange
World worldMock = mock(World.class);
Warzone zoneMock = mock(Warzone.class);
when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>());
when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>());
ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock);
Location nw = new Location(worldMock, -64, 64, 64);
// Act
Location existingCorner1 = new Location(worldMock, -32, 32, 32); // nw
volume.setCornerOne(existingCorner1); // corner 1 already set
Location existingCorner2 = new Location(worldMock, 32, 96, -32); // se
volume.setCornerTwo(existingCorner2); // corner 2 already set volume.setCornerTwo(existingCorner2); // corner 2 already set
volume.setNorthwest(blockMock); volume.setNorthwest(nw);
// Assert // Assert
// first corner should move but not along y // first corner should move but not along y
assertEquals(-64, volume.getCornerOne().getX()); Location movedOne = new Location(worldMock, -64, 32, 64);
assertEquals(32, volume.getCornerOne().getY()); assertEquals(movedOne, volume.getCornerOne());
assertEquals(64, volume.getCornerOne().getZ());
assertEquals(2, volume.getCornerOne().getTypeId());
assertEquals((byte)2, volume.getCornerOne().getData());
// second corner shouldn't move // second corner shouldn't move
assertEquals(32, volume.getCornerTwo().getX()); assertEquals(existingCorner2, volume.getCornerTwo());
assertEquals(96, volume.getCornerTwo().getY()); // moving an existing corner shouldn't change its height
assertEquals(-32, volume.getCornerTwo().getZ());
assertEquals(4, volume.getCornerTwo().getTypeId());
assertEquals((byte)4, volume.getCornerTwo().getData());
} }
@Test @Test
public void setNorthwest_whenChangingVolumeWithCorner1SeCorner2Nw_shouldMoveCorner2() throws NotNorthwestException, TooSmallException, TooBigException{ public void setNorthwest_whenChangingVolumeWithCorner1SeCorner2Nw_shouldMoveCorner2()
throws NotNorthwestException, TooSmallException, TooBigException {
// Arrange // Arrange
World worldMock = mock(World.class); World worldMock = mock(World.class);
@ -333,38 +216,27 @@ public class ZoneVolumeSpecTest {
when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>()); when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>());
when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>()); when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>());
ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock); ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock);
Block blockMock = mock(Block.class); Location nw = new Location(worldMock, -64, 64, 64);
when(blockMock.getX()).thenReturn(-64); // further north
when(blockMock.getY()).thenReturn(64); // at sea level
when(blockMock.getZ()).thenReturn(64); // further west
when(blockMock.getTypeId()).thenReturn(10);
when(blockMock.getData()).thenReturn((byte)2);
// Act // Act
BlockInfo existingCorner1 = new BlockInfo(32, 32, -32, 2, (byte)2); // corner 1 at maxX and minZ (se) Location existingCorner1 = new Location(worldMock, 32, 32, -32); // nw
volume.setCornerOne(existingCorner1); // corner 1 already set volume.setCornerOne(existingCorner1); // corner 1 already set
BlockInfo existingCorner2 = new BlockInfo(-32, 96, 32, 4, (byte)4); // corner 2 at minX and maxZ (nw) Location existingCorner2 = new Location(worldMock, -32, 96, 32); // se
volume.setCornerTwo(existingCorner2); // corner 2 already set volume.setCornerTwo(existingCorner2); // corner 2 already set
volume.setNorthwest(blockMock); volume.setNorthwest(nw);
// Assert // Assert
// first corner shouldn't move // first corner shouldn't move
assertEquals(32, volume.getCornerOne().getX()); assertEquals(existingCorner1, volume.getCornerOne());
assertEquals(32, volume.getCornerOne().getY());
assertEquals(-32, volume.getCornerOne().getZ());
assertEquals(2, volume.getCornerOne().getTypeId());
assertEquals((byte)2, volume.getCornerOne().getData());
// second corner should move but not along y // second corner should move but not along y
assertEquals(-64, volume.getCornerTwo().getX()); Location movedTwo = new Location(worldMock, -64, 96, 64);
assertEquals(96, volume.getCornerTwo().getY()); // moving an existing corner shouldn't change its height assertEquals(movedTwo, volume.getCornerTwo());
assertEquals(64, volume.getCornerTwo().getZ());
assertEquals(4, volume.getCornerTwo().getTypeId());
assertEquals((byte)4, volume.getCornerTwo().getData());
} }
@Test @Test
public void setNorthwest_whenChangingVolumeWithCorner1NeCorner2Sw_shouldMoveCorner1XAndCorner2Z() throws NotNorthwestException, TooSmallException, TooBigException{ public void setNorthwest_whenChangingVolumeWithCorner1NeCorner2Sw_shouldMoveCorner1XAndCorner2Z()
throws NotNorthwestException, TooSmallException, TooBigException {
// Arrange // Arrange
World worldMock = mock(World.class); World worldMock = mock(World.class);
@ -372,38 +244,28 @@ public class ZoneVolumeSpecTest {
when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>()); when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>());
when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>()); when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>());
ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock); ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock);
Block blockMock = mock(Block.class); Location nw = new Location(worldMock, -64, 64, 64);
when(blockMock.getX()).thenReturn(-64); // further north
when(blockMock.getY()).thenReturn(64); // at sea level
when(blockMock.getZ()).thenReturn(64); // further west
when(blockMock.getTypeId()).thenReturn(10);
when(blockMock.getData()).thenReturn((byte)2);
// Act // Act
BlockInfo existingCorner1 = new BlockInfo(-32, 32, -32, 2, (byte)2); // corner 1 at minX and minZ (ne) Location existingCorner1 = new Location(worldMock, -32, 32, -32); // ne
volume.setCornerOne(existingCorner1); // corner 1 already set volume.setCornerOne(existingCorner1); // corner 1 already set
BlockInfo existingCorner2 = new BlockInfo(32, 96, 32, 4, (byte)4); // corner 2 at maxX and maxZ (sw) Location existingCorner2 = new Location(worldMock, 32, 96, 32); // sw
volume.setCornerTwo(existingCorner2); // corner 2 already set volume.setCornerTwo(existingCorner2); // corner 2 already set
volume.setNorthwest(blockMock); volume.setNorthwest(nw);
// Assert // Assert
// first corner should move along x but not along y or z // first corner should move along x but not along y or z
assertEquals(-64, volume.getCornerOne().getX()); Location movedOne = new Location(worldMock, -64, 32, -32);
assertEquals(32, volume.getCornerOne().getY()); assertEquals(movedOne, volume.getCornerOne());
assertEquals(-32, volume.getCornerOne().getZ());
assertEquals(2, volume.getCornerOne().getTypeId());
assertEquals((byte)2, volume.getCornerOne().getData());
// second corner should move along z but not along x or y // second corner should move along z but not along x or y
assertEquals(32, volume.getCornerTwo().getX()); Location movedTwo = new Location(worldMock, 32, 96, 64);
assertEquals(96, volume.getCornerTwo().getY()); assertEquals(movedTwo, volume.getCornerTwo());
assertEquals(64, volume.getCornerTwo().getZ());
assertEquals(4, volume.getCornerTwo().getTypeId());
assertEquals((byte)4, volume.getCornerTwo().getData());
} }
@Test @Test
public void setNorthwest_whenChangingVolumeWithCorner1SwCorner2Ne_shouldMoveCorner1ZAndCorner2X() throws NotNorthwestException, TooSmallException, TooBigException{ public void setNorthwest_whenChangingVolumeWithCorner1SwCorner2Ne_shouldMoveCorner1ZAndCorner2X()
throws NotNorthwestException, TooSmallException, TooBigException {
// Arrange // Arrange
World worldMock = mock(World.class); World worldMock = mock(World.class);
@ -411,34 +273,23 @@ public class ZoneVolumeSpecTest {
when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>()); when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>());
when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>()); when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>());
ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock); ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock);
Block blockMock = mock(Block.class); Location nw = new Location(worldMock, -64, 64, 64);
when(blockMock.getX()).thenReturn(-64); // further north
when(blockMock.getY()).thenReturn(64); // at sea level
when(blockMock.getZ()).thenReturn(64); // further west
when(blockMock.getTypeId()).thenReturn(10);
when(blockMock.getData()).thenReturn((byte)2);
// Act // Act
BlockInfo existingCorner1 = new BlockInfo(32, 32, 32, 2, (byte)2); // corner 1 at maxX and maxZ (sw) Location existingCorner1 = new Location(worldMock, 32, 32, 32); // sw
volume.setCornerOne(existingCorner1); // corner 1 already set volume.setCornerOne(existingCorner1); // corner 1 already set
BlockInfo existingCorner2 = new BlockInfo(-32, 96, -32, 4, (byte)4); // corner 2 at minX and minZ (ne) Location existingCorner2 = new Location(worldMock, -32, 96, -32); // ne
volume.setCornerTwo(existingCorner2); // corner 2 already set volume.setCornerTwo(existingCorner2); // corner 2 already set
volume.setNorthwest(blockMock); volume.setNorthwest(nw);
// Assert // Assert
// first corner should move along z but not along x or y // first corner should move along z but not along x or y
assertEquals(32, volume.getCornerOne().getX()); Location movedOne = new Location(worldMock, 32, 32, 64);
assertEquals(32, volume.getCornerOne().getY()); assertEquals(movedOne, volume.getCornerOne());
assertEquals(64, volume.getCornerOne().getZ());
assertEquals(2, volume.getCornerOne().getTypeId());
assertEquals((byte)2, volume.getCornerOne().getData());
// second corner should move along x but not along y or z // second corner should move along x but not along y or z
assertEquals(-64, volume.getCornerTwo().getX()); Location movedTwo = new Location(worldMock, -64, 96, -32);
assertEquals(96, volume.getCornerTwo().getY()); assertEquals(movedTwo, volume.getCornerTwo());
assertEquals(-32, volume.getCornerTwo().getZ());
assertEquals(4, volume.getCornerTwo().getTypeId());
assertEquals((byte)4, volume.getCornerTwo().getData());
} }
// getNorthwestX // getNorthwestX
@ -448,7 +299,8 @@ public class ZoneVolumeSpecTest {
// setSoutheast // setSoutheast
@Test @Test
public void setSoutheast_whenCreatingAndNoCornersAreSet_shouldSetCorner2AtBottom() throws NotSoutheastException, TooSmallException, TooBigException{ public void setSoutheast_whenCreatingAndNoCornersAreSet_shouldSetCorner2AtBottom()
throws NotSoutheastException, TooSmallException, TooBigException {
// Arrange // Arrange
World worldMock = mock(World.class); World worldMock = mock(World.class);
@ -456,27 +308,19 @@ public class ZoneVolumeSpecTest {
when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>()); when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>());
when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>()); when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>());
ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock); ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock);
Block blockMock = mock(Block.class); Location se = new Location(worldMock, 0, 64, 0);
when(blockMock.getX()).thenReturn(0);
when(blockMock.getY()).thenReturn(64); // at sea level
when(blockMock.getZ()).thenReturn(0);
when(blockMock.getTypeId()).thenReturn(10);
when(blockMock.getData()).thenReturn((byte)2);
// Act // Act
volume.setSoutheast(blockMock); volume.setSoutheast(se);
// Assert // Assert
assertEquals(null, volume.getCornerOne()); Location movedOne = new Location(worldMock, 0, 0, 0);
assertEquals(0, volume.getCornerTwo().getX()); assertEquals(movedOne, volume.getCornerTwo());
assertEquals(0, volume.getCornerTwo().getY()); // the corner should shoot down
assertEquals(0, volume.getCornerTwo().getZ());
assertEquals(10, volume.getCornerTwo().getTypeId());
assertEquals((byte)2, volume.getCornerTwo().getData());
} }
@Test @Test(expected = NotSoutheastException.class)
public void setSoutheast_whenCreatingAndNoCorner2IsSet_ButCorner1IsAlreadySet_AndNewCornerBlockIsToWestOfCorner1_shouldThrowNotSoutheastException() throws TooSmallException, TooBigException{ public void setSoutheast_whenCreatingAndNoCorner2IsSet_ButCorner1IsAlreadySet_AndNewCornerBlockIsToWestOfCorner1_shouldThrowNotSoutheastException()
throws TooSmallException, TooBigException, NotSoutheastException {
// Arrange // Arrange
World worldMock = mock(World.class); World worldMock = mock(World.class);
@ -484,33 +328,17 @@ public class ZoneVolumeSpecTest {
when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>()); when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>());
when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>()); when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>());
ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock); ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock);
Block blockMock = mock(Block.class); Location se = new Location(worldMock, 64, 64, 64);
when(blockMock.getX()).thenReturn(64); // further south
when(blockMock.getY()).thenReturn(64); // at sea level
when(blockMock.getZ()).thenReturn(64); // further west
when(blockMock.getTypeId()).thenReturn(10);
when(blockMock.getData()).thenReturn((byte)2);
// Act // Act
BlockInfo existingCorner1 = new BlockInfo(0, 64, 0, 4, (byte)4); Location existingCorner1 = new Location(worldMock, 0, 64, 0);
volume.setCornerOne(existingCorner1); // corner 1 already set volume.setCornerOne(existingCorner1); // corner 1 already set
boolean failed = false; volume.setSoutheast(se);
try {
volume.setSoutheast(blockMock);
}
catch(NotSoutheastException e) {
failed = true;
} }
// Assert @Test(expected = NotSoutheastException.class)
// first corner shouldn't move public void setSoutheast_whenCreatingAndNoCorner2IsSet_ButCorner1IsAlreadySet_AndNewCornerBlockIsToNorthOfCorner1_shouldThrowNotSoutheastException()
assertTrue(failed); throws TooSmallException, TooBigException, NotSoutheastException {
assertEquals(null, volume.getCornerTwo());
assertEquals(existingCorner1, volume.getCornerOne());
}
@Test
public void setSoutheast_whenCreatingAndNoCorner2IsSet_ButCorner1IsAlreadySet_AndNewCornerBlockIsToNorthOfCorner1_shouldThrowNotSoutheastException() throws TooSmallException, TooBigException{
// Arrange // Arrange
World worldMock = mock(World.class); World worldMock = mock(World.class);
@ -518,33 +346,17 @@ public class ZoneVolumeSpecTest {
when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>()); when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>());
when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>()); when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>());
ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock); ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock);
Block blockMock = mock(Block.class); Location se = new Location(worldMock, -64, 64, -64);
when(blockMock.getX()).thenReturn(-64); // further north
when(blockMock.getY()).thenReturn(64); // at sea level
when(blockMock.getZ()).thenReturn(-64); // further east
when(blockMock.getTypeId()).thenReturn(10);
when(blockMock.getData()).thenReturn((byte)2);
// Act // Act
BlockInfo existingCorner1 = new BlockInfo(0, 64, 0, 4, (byte)4); Location existingCorner1 = new Location(worldMock, 0, 64, 0);
volume.setCornerOne(existingCorner1); // corner 1 already set volume.setCornerOne(existingCorner1); // corner 1 already set
boolean failed = false; volume.setSoutheast(se);
try {
volume.setSoutheast(blockMock);
}
catch(NotSoutheastException e) {
failed = true;
}
// Assert
// first corner shouldn't move
assertTrue(failed);
assertEquals(null, volume.getCornerTwo());
assertEquals(existingCorner1, volume.getCornerOne());
} }
@Test @Test
public void setSoutheast_whenCreatingAndCorner2AlreadySet_shouldSetCorner1AtBottom() throws NotSoutheastException, TooSmallException, TooBigException{ // se always goes to bottom public void setSoutheast_whenCreatingAndCorner2AlreadySet_shouldSetCorner1AtBottom()
throws NotSoutheastException, TooSmallException, TooBigException {
// Arrange // Arrange
World worldMock = mock(World.class); World worldMock = mock(World.class);
@ -552,69 +364,24 @@ public class ZoneVolumeSpecTest {
when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>()); when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>());
when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>()); when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>());
ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock); ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock);
Block blockMock = mock(Block.class); Location se = new Location(worldMock, 64, 64, -64);
when(blockMock.getX()).thenReturn(64); // further south
when(blockMock.getY()).thenReturn(64); // at sea level
when(blockMock.getZ()).thenReturn(-64); // further east
when(blockMock.getTypeId()).thenReturn(10);
when(blockMock.getData()).thenReturn((byte)2);
// Act // Act
BlockInfo existingCorner2 = new BlockInfo(0, 64, 0, 4, (byte)4); Location existingCorner2 = new Location(worldMock, 0, 64, 0);
volume.setCornerTwo(existingCorner2); // corner 2 already set volume.setCornerTwo(existingCorner2); // corner 2 already set
volume.setSoutheast(blockMock); volume.setSoutheast(se);
// Assert // Assert
// first corner shouldn't move // first corner shouldn't move
assertEquals(0, volume.getCornerTwo().getX());
assertEquals(64, volume.getCornerTwo().getY());
assertEquals(0, volume.getCornerTwo().getZ());
assertEquals(4, volume.getCornerTwo().getTypeId());
assertEquals((byte)4, volume.getCornerTwo().getData());
assertEquals(64, volume.getCornerOne().getX());
assertEquals(0, volume.getCornerOne().getY()); // the new corner should shoot down
assertEquals(-64, volume.getCornerOne().getZ());
assertEquals(10, volume.getCornerOne().getTypeId());
assertEquals((byte)2, volume.getCornerOne().getData());
}
@Test
public void setSoutheast_whenCreating_AndCorner2AlreadySet_ButNewCornerBlockIsToWestOfCorner2_shouldThrowNotSoutheastException() throws TooSmallException, TooBigException{
// Arrange
World worldMock = mock(World.class);
Warzone zoneMock = mock(Warzone.class);
when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>());
when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>());
ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock);
Block blockMock = mock(Block.class);
when(blockMock.getX()).thenReturn(64); // further south
when(blockMock.getY()).thenReturn(64); // at sea level
when(blockMock.getZ()).thenReturn(64); // further west
when(blockMock.getTypeId()).thenReturn(10);
when(blockMock.getData()).thenReturn((byte)2);
// Act
BlockInfo existingCorner2 = new BlockInfo(0, 64, 0, 4, (byte)4);
volume.setCornerTwo(existingCorner2); // corner 2 already set
boolean failed = false;
try {
volume.setSoutheast(blockMock);
}
catch(NotSoutheastException e) {
failed = true;
}
// Assert
// first corner shouldn't move
assertTrue(failed);
assertEquals(null, volume.getCornerOne());
assertEquals(existingCorner2, volume.getCornerTwo()); assertEquals(existingCorner2, volume.getCornerTwo());
Location movedSe = new Location(worldMock, 64, 0, -64);
assertEquals(movedSe, volume.getCornerOne());
} }
@Test @Test(expected = NotSoutheastException.class)
public void setSoutheast_whenCreating_AndCorner2AlreadySet_ButNewCornerBlockIsToNorthOfCorner2_shouldThrowNotSoutheastException() throws TooSmallException, TooBigException{ public void setSoutheast_whenCreating_AndCorner2AlreadySet_ButNewCornerBlockIsToWestOfCorner2_shouldThrowNotSoutheastException()
throws TooSmallException, TooBigException, NotSoutheastException {
// Arrange // Arrange
World worldMock = mock(World.class); World worldMock = mock(World.class);
@ -622,33 +389,17 @@ public class ZoneVolumeSpecTest {
when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>()); when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>());
when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>()); when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>());
ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock); ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock);
Block blockMock = mock(Block.class); Location se = new Location(worldMock, 64, 64, 64);
when(blockMock.getX()).thenReturn(-64); // further north
when(blockMock.getY()).thenReturn(64); // at sea level
when(blockMock.getZ()).thenReturn(-64); // further east
when(blockMock.getTypeId()).thenReturn(10);
when(blockMock.getData()).thenReturn((byte)2);
// Act // Act
BlockInfo existingCorner2 = new BlockInfo(0, 64, 0, 4, (byte)4); Location existingCorner2 = new Location(worldMock, 0, 64, 0);
volume.setCornerTwo(existingCorner2); // corner 2 already set volume.setCornerTwo(existingCorner2); // corner 2 already set
boolean failed = false; volume.setSoutheast(se);
try {
volume.setSoutheast(blockMock);
}
catch(NotSoutheastException e) {
failed = true;
} }
// Assert @Test(expected = NotSoutheastException.class)
// first corner shouldn't move public void setSoutheast_whenCreating_AndCorner2AlreadySet_ButNewCornerBlockIsToNorthOfCorner2_shouldThrowNotSoutheastException()
assertTrue(failed); throws TooSmallException, TooBigException, NotSoutheastException {
assertEquals(null, volume.getCornerOne());
assertEquals(existingCorner2, volume.getCornerTwo());
}
@Test
public void setSoutheast_whenChangingVolumeWithCorner1NwCorner2Se_shouldMoveCorner2() throws NotSoutheastException, TooSmallException, TooBigException{
// Arrange // Arrange
World worldMock = mock(World.class); World worldMock = mock(World.class);
@ -656,38 +407,45 @@ public class ZoneVolumeSpecTest {
when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>()); when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>());
when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>()); when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>());
ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock); ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock);
Block blockMock = mock(Block.class); Location se = new Location(worldMock, -64, 64, -64);
when(blockMock.getX()).thenReturn(64); // further south
when(blockMock.getY()).thenReturn(64); // at sea level
when(blockMock.getZ()).thenReturn(-64); // further east
when(blockMock.getTypeId()).thenReturn(10);
when(blockMock.getData()).thenReturn((byte)2);
// Act // Act
BlockInfo existingCorner1 = new BlockInfo(-32, 32, 32, 2, (byte)2); // corner 1 at minX and maxZ (nw) Location existingCorner2 = new Location(worldMock, 0, 64, 0);
volume.setCornerTwo(existingCorner2); // corner 2 already set
volume.setSoutheast(se);
}
@Test
public void setSoutheast_whenChangingVolumeWithCorner1NwCorner2Se_shouldMoveCorner2()
throws NotSoutheastException, TooSmallException, TooBigException {
// Arrange
World worldMock = mock(World.class);
Warzone zoneMock = mock(Warzone.class);
when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>());
when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>());
ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock);
Location se = new Location(worldMock, 64, 64, -64);
// Act
Location existingCorner1 = new Location(worldMock, -32, 32, 32); // nw
volume.setCornerOne(existingCorner1); // corner 1 already set volume.setCornerOne(existingCorner1); // corner 1 already set
BlockInfo existingCorner2 = new BlockInfo(32, 96, -32, 4, (byte)4); // corner 2 at maxX and minZ (se) Location existingCorner2 = new Location(worldMock, 32, 96, -32); // se
volume.setCornerTwo(existingCorner2); // corner 2 already set volume.setCornerTwo(existingCorner2); // corner 2 already set
volume.setSoutheast(blockMock); volume.setSoutheast(se);
// Assert // Assert
// first corner shouldn't move // first corner shouldn't move
assertEquals(-32, volume.getCornerOne().getX()); assertEquals(existingCorner1, volume.getCornerOne());
assertEquals(32, volume.getCornerOne().getY());
assertEquals(32, volume.getCornerOne().getZ());
assertEquals(2, volume.getCornerOne().getTypeId());
assertEquals((byte)2, volume.getCornerOne().getData());
// second corner should move but not along y // second corner should move but not along y
assertEquals(64, volume.getCornerTwo().getX()); Location movedTwo = new Location(worldMock, 64, 96, -64);
assertEquals(96, volume.getCornerTwo().getY()); assertEquals(movedTwo, volume.getCornerTwo());
assertEquals(-64, volume.getCornerTwo().getZ());
assertEquals(4, volume.getCornerTwo().getTypeId());
assertEquals((byte)4, volume.getCornerTwo().getData());
} }
@Test @Test
public void setSoutheast_whenChangingVolumeWithCorner1SeCorner2Nw_shouldMoveCorner1() throws NotSoutheastException, TooSmallException, TooBigException{ public void setSoutheast_whenChangingVolumeWithCorner1SeCorner2Nw_shouldMoveCorner1()
throws NotSoutheastException, TooSmallException, TooBigException {
// Arrange // Arrange
World worldMock = mock(World.class); World worldMock = mock(World.class);
@ -695,38 +453,27 @@ public class ZoneVolumeSpecTest {
when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>()); when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>());
when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>()); when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>());
ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock); ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock);
Block blockMock = mock(Block.class); Location se = new Location(worldMock, 64, 64, -64);
when(blockMock.getX()).thenReturn(64); // further south
when(blockMock.getY()).thenReturn(64); // at sea level
when(blockMock.getZ()).thenReturn(-64); // further east
when(blockMock.getTypeId()).thenReturn(10);
when(blockMock.getData()).thenReturn((byte)2);
// Act // Act
BlockInfo existingCorner1 = new BlockInfo(32, 32, -32, 2, (byte)2); // corner 1 at maxX and minZ (se) Location existingCorner1 = new Location(worldMock, 32, 32, -32); // se
volume.setCornerOne(existingCorner1); // corner 1 already set volume.setCornerOne(existingCorner1); // corner 1 already set
BlockInfo existingCorner2 = new BlockInfo(-32, 96, 32, 4, (byte)4); // corner 2 at minX and maxZ (nw) Location existingCorner2 = new Location(worldMock, -32, 96, 32); // nw
volume.setCornerTwo(existingCorner2); // corner 2 already set volume.setCornerTwo(existingCorner2); // corner 2 already set
volume.setSoutheast(blockMock); volume.setSoutheast(se);
// Assert // Assert
// first corner should move but not along y // first corner should move but not along y
assertEquals(64, volume.getCornerOne().getX()); Location movedOne = new Location(worldMock, 64, 32, -64);
assertEquals(32, volume.getCornerOne().getY()); assertEquals(movedOne, volume.getCornerOne());
assertEquals(-64, volume.getCornerOne().getZ());
assertEquals(2, volume.getCornerOne().getTypeId());
assertEquals((byte)2, volume.getCornerOne().getData());
// second corner shouldn't move // second corner shouldn't move
assertEquals(-32, volume.getCornerTwo().getX()); assertEquals(existingCorner2, volume.getCornerTwo());
assertEquals(96, volume.getCornerTwo().getY());
assertEquals(32, volume.getCornerTwo().getZ());
assertEquals(4, volume.getCornerTwo().getTypeId());
assertEquals((byte)4, volume.getCornerTwo().getData());
} }
@Test @Test
public void setSoutheast_whenChangingVolumeWithCorner1NeCorner2Sw_shouldMoveCorner1ZAndCorner2X() throws NotSoutheastException, TooSmallException, TooBigException{ public void setSoutheast_whenChangingVolumeWithCorner1NeCorner2Sw_shouldMoveCorner1ZAndCorner2X()
throws NotSoutheastException, TooSmallException, TooBigException {
// Arrange // Arrange
World worldMock = mock(World.class); World worldMock = mock(World.class);
@ -734,38 +481,28 @@ public class ZoneVolumeSpecTest {
when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>()); when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>());
when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>()); when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>());
ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock); ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock);
Block blockMock = mock(Block.class); Location se = new Location(worldMock, 64, 64, -64);
when(blockMock.getX()).thenReturn(64); // further south
when(blockMock.getY()).thenReturn(64); // at sea level
when(blockMock.getZ()).thenReturn(-64); // further east
when(blockMock.getTypeId()).thenReturn(10);
when(blockMock.getData()).thenReturn((byte)2);
// Act // Act
BlockInfo existingCorner1 = new BlockInfo(-32, 32, -32, 2, (byte)2); // corner 1 at minX and minZ (ne) Location existingCorner1 = new Location(worldMock, -32, 32, -32); // ne
volume.setCornerOne(existingCorner1); // corner 1 already set volume.setCornerOne(existingCorner1); // corner 1 already set
BlockInfo existingCorner2 = new BlockInfo(32, 96, 32, 4, (byte)4); // corner 2 at maxX and maxZ (sw) Location existingCorner2 = new Location(worldMock, 32, 96, 32); // sw
volume.setCornerTwo(existingCorner2); // corner 2 already set volume.setCornerTwo(existingCorner2); // corner 2 already set
volume.setSoutheast(blockMock); volume.setSoutheast(se);
// Assert // Assert
// first corner should move along z but not along x or y // first corner should move along z but not along x or y
assertEquals(-32, volume.getCornerOne().getX()); Location movedOne = new Location(worldMock, -32, 32, -64);
assertEquals(32, volume.getCornerOne().getY()); assertEquals(movedOne, volume.getCornerOne());
assertEquals(-64, volume.getCornerOne().getZ());
assertEquals(2, volume.getCornerOne().getTypeId());
assertEquals((byte)2, volume.getCornerOne().getData());
// second corner should move along x but not along y or z // second corner should move along x but not along y or z
assertEquals(64, volume.getCornerTwo().getX()); Location movedTwo = new Location(worldMock, 64, 96, 32);
assertEquals(96, volume.getCornerTwo().getY()); assertEquals(movedTwo, volume.getCornerTwo());
assertEquals(32, volume.getCornerTwo().getZ());
assertEquals(4, volume.getCornerTwo().getTypeId());
assertEquals((byte)4, volume.getCornerTwo().getData());
} }
@Test @Test
public void setSoutheast_whenChangingVolumeWithCorner1SwCorner2Ne_shouldMoveCorner1XAndCorner2Z() throws NotSoutheastException, TooSmallException, TooBigException{ public void setSoutheast_whenChangingVolumeWithCorner1SwCorner2Ne_shouldMoveCorner1XAndCorner2Z()
throws NotSoutheastException, TooSmallException, TooBigException {
// Arrange // Arrange
World worldMock = mock(World.class); World worldMock = mock(World.class);
@ -773,34 +510,23 @@ public class ZoneVolumeSpecTest {
when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>()); when(zoneMock.getTeams()).thenReturn(new ArrayList<Team>());
when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>()); when(zoneMock.getMonuments()).thenReturn(new ArrayList<Monument>());
ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock); ZoneVolume volume = new ZoneVolume("test", worldMock, zoneMock);
Block blockMock = mock(Block.class); Location se = new Location(worldMock, 64, 64, -64);
when(blockMock.getX()).thenReturn(64); // further south
when(blockMock.getY()).thenReturn(64); // at sea level
when(blockMock.getZ()).thenReturn(-64); // further east
when(blockMock.getTypeId()).thenReturn(10);
when(blockMock.getData()).thenReturn((byte)2);
// Act // Act
BlockInfo existingCorner1 = new BlockInfo(32, 32, 32, 2, (byte)2); // corner 1 at maxX and maxZ (sw) Location existingCorner1 = new Location(worldMock, 32, 32, 32); // sw
volume.setCornerOne(existingCorner1); // corner 1 already set volume.setCornerOne(existingCorner1); // corner 1 already set
BlockInfo existingCorner2 = new BlockInfo(-32, 96, -32, 4, (byte)4); // corner 2 at minX and minZ (ne) Location existingCorner2 = new Location(worldMock, -32, 96, -32); // ne
volume.setCornerTwo(existingCorner2); // corner 2 already set volume.setCornerTwo(existingCorner2); // corner 2 already set
volume.setSoutheast(blockMock); volume.setSoutheast(se);
// Assert // Assert
// first corner should move along x but not along y or z // first corner should move along x but not along y or z
assertEquals(64, volume.getCornerOne().getX()); Location movedOne = new Location(worldMock, 64, 32, 32);
assertEquals(32, volume.getCornerOne().getY()); assertEquals(movedOne, volume.getCornerOne());
assertEquals(32, volume.getCornerOne().getZ());
assertEquals(2, volume.getCornerOne().getTypeId());
assertEquals((byte)2, volume.getCornerOne().getData());
// second corner should move along z but not along x or y // second corner should move along z but not along x or y
assertEquals(-32, volume.getCornerTwo().getX()); Location movedTwo = new Location(worldMock, -32, 96, -64);
assertEquals(96, volume.getCornerTwo().getY()); assertEquals(movedTwo, volume.getCornerTwo());
assertEquals(-64, volume.getCornerTwo().getZ());
assertEquals(4, volume.getCornerTwo().getTypeId());
assertEquals((byte)4, volume.getCornerTwo().getData());
} }
// getSoutheastX // getSoutheastX