mirror of
https://github.com/BentoBoxWorld/BentoBox.git
synced 2024-11-24 11:45:31 +01:00
Added world condition in IslandsManager#userIsOnIsland
The world parameter was previously unused. I also updated javadocs ; as well as the tests. Everything seems to be working fine.
This commit is contained in:
parent
033e278f11
commit
480d3f78d9
@ -623,18 +623,20 @@ public class IslandsManager {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Checks if an online player is in the protected area of their island, a team island or a
|
* Checks if an online player is in the protected area of an island he owns or he is part of.
|
||||||
* coop island in the specific world in the arguments.
|
|
||||||
*
|
*
|
||||||
* @param world - the world to check
|
* @param world the World to check, if null the method will always return {@code false}.
|
||||||
* @param user - the user
|
* @param user the User to check, if null or if this is not a Player the method will always return {@code false}.
|
||||||
* @return true if on their island in world, false if not
|
*
|
||||||
|
* @return {@code true} if this User is located within the protected area of an island he owns or he is part of,
|
||||||
|
* {@code false} otherwise or if this User is not located in this World.
|
||||||
*/
|
*/
|
||||||
public boolean userIsOnIsland(World world, User user) {
|
public boolean userIsOnIsland(World world, User user) {
|
||||||
if (user == null) {
|
if (user == null || !user.isPlayer() || world == null) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return getProtectedIslandAt(user.getLocation())
|
return (user.getLocation().getWorld() == world)
|
||||||
|
&& getProtectedIslandAt(user.getLocation())
|
||||||
.map(i -> i.getMembers().entrySet().stream()
|
.map(i -> i.getMembers().entrySet().stream()
|
||||||
.anyMatch(en -> en.getKey().equals(user.getUniqueId()) && en.getValue() > RanksManager.VISITOR_RANK))
|
.anyMatch(en -> en.getKey().equals(user.getUniqueId()) && en.getValue() > RanksManager.VISITOR_RANK))
|
||||||
.orElse(false);
|
.orElse(false);
|
||||||
|
@ -811,30 +811,46 @@ public class IslandsManagerTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Test method for user is on island
|
* Test method for {@link IslandsManager#userIsOnIsland(World, User)}.
|
||||||
* @throws Exception
|
|
||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testUserIsOnIsland() throws Exception {
|
public void testUserIsOnIsland() {
|
||||||
IslandsManager im = new IslandsManager(plugin);
|
IslandsManager im = new IslandsManager(plugin);
|
||||||
im.setIslandCache(islandCache);
|
im.setIslandCache(islandCache);
|
||||||
|
|
||||||
|
// ----- CHECK INVALID ARGUMENTS -----
|
||||||
|
|
||||||
// Null user
|
// Null user
|
||||||
assertFalse(im.userIsOnIsland(world, null));
|
assertFalse(im.userIsOnIsland(world, null));
|
||||||
|
|
||||||
|
// Null world
|
||||||
|
assertFalse(im.userIsOnIsland(null, user));
|
||||||
|
|
||||||
// User is on island is determined by whether the user's location is on
|
// Both null user and null world
|
||||||
// an island that has them as a member (rank > 0)
|
assertFalse(im.userIsOnIsland(null, null));
|
||||||
|
|
||||||
|
// User is not a player
|
||||||
|
when(user.isPlayer()).thenReturn(false);
|
||||||
|
assertFalse(im.userIsOnIsland(world, user));
|
||||||
|
|
||||||
|
// ----- CHECK MEMBERSHIP -----
|
||||||
|
// We assume there that the User is in the good World.
|
||||||
|
when(user.getLocation().getWorld()).thenReturn(world);
|
||||||
|
when(user.isPlayer()).thenReturn(true);
|
||||||
|
|
||||||
|
// The method returns true if the user's location is on an island that has them as member (rank >= MEMBER)
|
||||||
when(is.onIsland(Mockito.any())).thenReturn(true);
|
when(is.onIsland(Mockito.any())).thenReturn(true);
|
||||||
Map<UUID, Integer> members = new HashMap<>();
|
Map<UUID, Integer> members = new HashMap<>();
|
||||||
when(is.getMembers()).thenReturn(members);
|
when(is.getMembers()).thenReturn(members);
|
||||||
|
|
||||||
|
// -- The user is not part of the island --
|
||||||
assertFalse(im.userIsOnIsland(world, user));
|
assertFalse(im.userIsOnIsland(world, user));
|
||||||
|
|
||||||
// One member, just the owner
|
// -- The user is the owner of the island --
|
||||||
members.put(user.getUniqueId(), RanksManager.MEMBER_RANK);
|
members.put(user.getUniqueId(), RanksManager.OWNER_RANK);
|
||||||
assertTrue(im.userIsOnIsland(world, user));
|
assertTrue(im.userIsOnIsland(world, user));
|
||||||
|
|
||||||
// Add some members
|
// Add some members to see if it still works
|
||||||
members.put(UUID.randomUUID(), RanksManager.MEMBER_RANK);
|
members.put(UUID.randomUUID(), RanksManager.MEMBER_RANK);
|
||||||
members.put(UUID.randomUUID(), RanksManager.MEMBER_RANK);
|
members.put(UUID.randomUUID(), RanksManager.MEMBER_RANK);
|
||||||
members.put(UUID.randomUUID(), RanksManager.MEMBER_RANK);
|
members.put(UUID.randomUUID(), RanksManager.MEMBER_RANK);
|
||||||
@ -844,7 +860,7 @@ public class IslandsManagerTest {
|
|||||||
members.put(UUID.randomUUID(), RanksManager.MEMBER_RANK);
|
members.put(UUID.randomUUID(), RanksManager.MEMBER_RANK);
|
||||||
assertTrue(im.userIsOnIsland(world, user));
|
assertTrue(im.userIsOnIsland(world, user));
|
||||||
|
|
||||||
// Add some other ranks
|
// Add some other ranks to see if it still works
|
||||||
members.put(UUID.randomUUID(), RanksManager.BANNED_RANK);
|
members.put(UUID.randomUUID(), RanksManager.BANNED_RANK);
|
||||||
members.put(UUID.randomUUID(), RanksManager.BANNED_RANK);
|
members.put(UUID.randomUUID(), RanksManager.BANNED_RANK);
|
||||||
members.put(UUID.randomUUID(), RanksManager.COOP_RANK);
|
members.put(UUID.randomUUID(), RanksManager.COOP_RANK);
|
||||||
@ -852,9 +868,39 @@ public class IslandsManagerTest {
|
|||||||
members.put(UUID.randomUUID(), RanksManager.BANNED_RANK);
|
members.put(UUID.randomUUID(), RanksManager.BANNED_RANK);
|
||||||
assertTrue(im.userIsOnIsland(world, user));
|
assertTrue(im.userIsOnIsland(world, user));
|
||||||
|
|
||||||
// Confirm that if user is not above Member rank then it fails
|
// -- The user is a sub-owner on the island --
|
||||||
|
members.put(user.getUniqueId(), RanksManager.SUB_OWNER_RANK);
|
||||||
|
assertTrue(im.userIsOnIsland(world, user));
|
||||||
|
|
||||||
|
// -- The user is a member on the island --
|
||||||
|
members.put(user.getUniqueId(), RanksManager.MEMBER_RANK);
|
||||||
|
assertTrue(im.userIsOnIsland(world, user));
|
||||||
|
|
||||||
|
// -- The user is a trusted on the island --
|
||||||
|
members.put(user.getUniqueId(), RanksManager.TRUSTED_RANK);
|
||||||
|
assertTrue(im.userIsOnIsland(world, user));
|
||||||
|
|
||||||
|
// -- The user is a coop on the island --
|
||||||
|
members.put(user.getUniqueId(), RanksManager.COOP_RANK);
|
||||||
|
assertTrue(im.userIsOnIsland(world, user));
|
||||||
|
|
||||||
|
// -- The user is a visitor on the island --
|
||||||
|
members.remove(user.getUniqueId());
|
||||||
|
assertFalse(im.userIsOnIsland(world, user));
|
||||||
|
|
||||||
|
// -- The user is explicitly a visitor on the island --
|
||||||
|
members.put(user.getUniqueId(), RanksManager.VISITOR_RANK);
|
||||||
|
assertFalse(im.userIsOnIsland(world, user));
|
||||||
|
|
||||||
|
// -- The user is banned from the island --
|
||||||
members.put(user.getUniqueId(), RanksManager.BANNED_RANK);
|
members.put(user.getUniqueId(), RanksManager.BANNED_RANK);
|
||||||
assertFalse(im.userIsOnIsland(world, user));
|
assertFalse(im.userIsOnIsland(world, user));
|
||||||
|
|
||||||
|
// ----- CHECK WORLD -----
|
||||||
|
// Assertions above succeeded, so let's check that again with the User being a MEMBER and being in the wrong world.
|
||||||
|
when(user.getLocation().getWorld()).thenReturn(mock(World.class));
|
||||||
|
members.put(user.getUniqueId(), RanksManager.MEMBER_RANK);
|
||||||
|
assertFalse(im.userIsOnIsland(world, user));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Loading…
Reference in New Issue
Block a user