mirror of
https://github.com/BentoBoxWorld/Challenges.git
synced 2024-09-29 15:07:27 +02:00
Added ChallengesManager test class
This commit is contained in:
parent
9d8e1ddfd8
commit
38bd555b24
@ -19,6 +19,7 @@ import java.util.stream.Collectors;
|
|||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.World;
|
import org.bukkit.World;
|
||||||
import org.eclipse.jdt.annotation.NonNull;
|
import org.eclipse.jdt.annotation.NonNull;
|
||||||
|
import org.eclipse.jdt.annotation.Nullable;
|
||||||
|
|
||||||
import world.bentobox.bentobox.api.logs.LogEntry;
|
import world.bentobox.bentobox.api.logs.LogEntry;
|
||||||
import world.bentobox.bentobox.api.user.User;
|
import world.bentobox.bentobox.api.user.User;
|
||||||
@ -189,6 +190,7 @@ public class ChallengesManager
|
|||||||
*/
|
*/
|
||||||
public void load()
|
public void load()
|
||||||
{
|
{
|
||||||
|
this.addon.log("Loading challenges...");
|
||||||
this.challengeCacheData.clear();
|
this.challengeCacheData.clear();
|
||||||
this.levelCacheData.clear();
|
this.levelCacheData.clear();
|
||||||
|
|
||||||
@ -199,17 +201,15 @@ public class ChallengesManager
|
|||||||
}
|
}
|
||||||
|
|
||||||
this.playerCacheData.clear();
|
this.playerCacheData.clear();
|
||||||
|
loadAndValidate();
|
||||||
|
}
|
||||||
|
|
||||||
this.addon.log("Loading challenges...");
|
|
||||||
|
|
||||||
|
private void loadAndValidate() {
|
||||||
this.challengeDatabase.loadObjects().forEach(this::loadChallenge);
|
this.challengeDatabase.loadObjects().forEach(this::loadChallenge);
|
||||||
this.levelDatabase.loadObjects().forEach(this::loadLevel);
|
this.levelDatabase.loadObjects().forEach(this::loadLevel);
|
||||||
|
|
||||||
// this validate challenge levels
|
// this validate challenge levels
|
||||||
this.validateChallenges();
|
this.validateChallenges();
|
||||||
|
|
||||||
// It is not necessary to load all players in memory.
|
|
||||||
// this.playersDatabase.loadObjects().forEach(this::loadPlayerData);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -218,24 +218,17 @@ public class ChallengesManager
|
|||||||
*/
|
*/
|
||||||
public void reload()
|
public void reload()
|
||||||
{
|
{
|
||||||
|
this.addon.log("Reloading challenges...");
|
||||||
if (!this.playerCacheData.isEmpty())
|
if (!this.playerCacheData.isEmpty())
|
||||||
{
|
{
|
||||||
// store player data before cleaning.
|
// store player data before cleaning.
|
||||||
this.savePlayersData();
|
this.savePlayersData();
|
||||||
}
|
}
|
||||||
|
//this.challengeDatabase = new Database<>(addon, Challenge.class);
|
||||||
|
//this.levelDatabase = new Database<>(addon, ChallengeLevel.class);
|
||||||
|
//this.playersDatabase = new Database<>(addon, ChallengesPlayerData.class);
|
||||||
|
|
||||||
this.addon.getLogger().info("Reloading challenges...");
|
loadAndValidate();
|
||||||
|
|
||||||
this.challengeDatabase = new Database<>(addon, Challenge.class);
|
|
||||||
this.levelDatabase = new Database<>(addon, ChallengeLevel.class);
|
|
||||||
this.playersDatabase = new Database<>(addon, ChallengesPlayerData.class);
|
|
||||||
|
|
||||||
this.challengeDatabase.loadObjects().forEach(this::loadChallenge);
|
|
||||||
this.levelDatabase.loadObjects().forEach(this::loadLevel);
|
|
||||||
|
|
||||||
this.validateChallenges();
|
|
||||||
// It is not necessary to load all players in memory.
|
|
||||||
// this.playersDatabase.loadObjects().forEach(this::loadPlayerData);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -1068,6 +1061,7 @@ public class ChallengesManager
|
|||||||
* @param gameMode - World Name where levels should be searched.
|
* @param gameMode - World Name where levels should be searched.
|
||||||
* @return Level status - how many challenges still to do on which level
|
* @return Level status - how many challenges still to do on which level
|
||||||
*/
|
*/
|
||||||
|
@NonNull
|
||||||
private List<LevelStatus> getAllChallengeLevelStatus(String storageDataID, String gameMode)
|
private List<LevelStatus> getAllChallengeLevelStatus(String storageDataID, String gameMode)
|
||||||
{
|
{
|
||||||
this.addPlayerData(storageDataID);
|
this.addPlayerData(storageDataID);
|
||||||
@ -1103,7 +1097,6 @@ public class ChallengesManager
|
|||||||
|
|
||||||
previousLevel = level;
|
previousLevel = level;
|
||||||
}
|
}
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1115,6 +1108,7 @@ public class ChallengesManager
|
|||||||
* @param level Level which status must be calculated.
|
* @param level Level which status must be calculated.
|
||||||
* @return LevelStatus of given level.
|
* @return LevelStatus of given level.
|
||||||
*/
|
*/
|
||||||
|
@Nullable
|
||||||
private LevelStatus getChallengeLevelStatus(@NonNull String storageDataID, World world, @NonNull ChallengeLevel level)
|
private LevelStatus getChallengeLevelStatus(@NonNull String storageDataID, World world, @NonNull ChallengeLevel level)
|
||||||
{
|
{
|
||||||
this.addPlayerData(storageDataID);
|
this.addPlayerData(storageDataID);
|
||||||
@ -1148,29 +1142,6 @@ public class ChallengesManager
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Check is playerData can see given level.
|
|
||||||
* TODO: not an optimal way. Faster would be to check previous level challenges.
|
|
||||||
* @param storageDataID - playerData ID
|
|
||||||
* @param level - level
|
|
||||||
* @return true if level is unlocked
|
|
||||||
*/
|
|
||||||
private boolean isLevelUnlocked(@NonNull String storageDataID,
|
|
||||||
World world,
|
|
||||||
ChallengeLevel level)
|
|
||||||
{
|
|
||||||
this.addPlayerData(storageDataID);
|
|
||||||
|
|
||||||
return this.islandWorldManager.getAddon(world).filter(gameMode ->
|
|
||||||
this.getAllChallengeLevelStatus(storageDataID, gameMode.getDescription().getName()).
|
|
||||||
stream().
|
|
||||||
filter(LevelStatus::isUnlocked).
|
|
||||||
anyMatch(lv -> lv.getLevel().equals(level))).
|
|
||||||
isPresent();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This method returns if given user has been already completed given level.
|
* This method returns if given user has been already completed given level.
|
||||||
* @param levelID Level that must be checked.
|
* @param levelID Level that must be checked.
|
||||||
@ -1308,7 +1279,7 @@ public class ChallengesManager
|
|||||||
build());
|
build());
|
||||||
|
|
||||||
// Fire event that user completes challenge
|
// Fire event that user completes challenge
|
||||||
Bukkit.getServer().getPluginManager().callEvent(
|
Bukkit.getPluginManager().callEvent(
|
||||||
new ChallengeCompletedEvent(challenge.getUniqueId(),
|
new ChallengeCompletedEvent(challenge.getUniqueId(),
|
||||||
userID,
|
userID,
|
||||||
false,
|
false,
|
||||||
@ -1335,7 +1306,7 @@ public class ChallengesManager
|
|||||||
build());
|
build());
|
||||||
|
|
||||||
// Fire event that admin completes user challenge
|
// Fire event that admin completes user challenge
|
||||||
Bukkit.getServer().getPluginManager().callEvent(
|
Bukkit.getPluginManager().callEvent(
|
||||||
new ChallengeCompletedEvent(challenge.getUniqueId(),
|
new ChallengeCompletedEvent(challenge.getUniqueId(),
|
||||||
userID,
|
userID,
|
||||||
true,
|
true,
|
||||||
@ -1361,7 +1332,7 @@ public class ChallengesManager
|
|||||||
build());
|
build());
|
||||||
|
|
||||||
// Fire event that admin resets user challenge
|
// Fire event that admin resets user challenge
|
||||||
Bukkit.getServer().getPluginManager().callEvent(
|
Bukkit.getPluginManager().callEvent(
|
||||||
new ChallengeResetEvent(challenge.getUniqueId(),
|
new ChallengeResetEvent(challenge.getUniqueId(),
|
||||||
userID,
|
userID,
|
||||||
true,
|
true,
|
||||||
@ -1398,7 +1369,7 @@ public class ChallengesManager
|
|||||||
build());
|
build());
|
||||||
|
|
||||||
// Fire event that admin resets user challenge
|
// Fire event that admin resets user challenge
|
||||||
Bukkit.getServer().getPluginManager().callEvent(
|
Bukkit.getPluginManager().callEvent(
|
||||||
new ChallengeResetAllEvent(gameMode.getDescription().getName(),
|
new ChallengeResetAllEvent(gameMode.getDescription().getName(),
|
||||||
userID,
|
userID,
|
||||||
adminID != null,
|
adminID != null,
|
||||||
@ -1454,11 +1425,19 @@ public class ChallengesManager
|
|||||||
* @param world World where level must be checked.
|
* @param world World where level must be checked.
|
||||||
* @param level Level that must be checked.
|
* @param level Level that must be checked.
|
||||||
* @param user User who need to be checked.
|
* @param user User who need to be checked.
|
||||||
* @return true, if level is already completed.
|
* @return true, if level is unlocked.
|
||||||
*/
|
*/
|
||||||
public boolean isLevelUnlocked(User user, World world, ChallengeLevel level)
|
public boolean isLevelUnlocked(User user, World world, ChallengeLevel level)
|
||||||
{
|
{
|
||||||
return this.isLevelUnlocked(this.getDataUniqueID(user, Util.getWorld(world)), world, level);
|
String storageDataID = this.getDataUniqueID(user, Util.getWorld(world));
|
||||||
|
this.addPlayerData(storageDataID);
|
||||||
|
|
||||||
|
return this.islandWorldManager.getAddon(world).filter(gameMode -> this.getAllChallengeLevelStatus(storageDataID, gameMode.getDescription().getName()).
|
||||||
|
stream().
|
||||||
|
filter(LevelStatus::isUnlocked).
|
||||||
|
anyMatch(lv -> lv.getLevel().equals(level))).
|
||||||
|
isPresent();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -1478,7 +1457,7 @@ public class ChallengesManager
|
|||||||
data("level", level.getUniqueId()).build());
|
data("level", level.getUniqueId()).build());
|
||||||
|
|
||||||
// Fire event that user completes level
|
// Fire event that user completes level
|
||||||
Bukkit.getServer().getPluginManager().callEvent(
|
Bukkit.getPluginManager().callEvent(
|
||||||
new LevelCompletedEvent(level.getUniqueId(),
|
new LevelCompletedEvent(level.getUniqueId(),
|
||||||
user.getUniqueId(),
|
user.getUniqueId(),
|
||||||
false));
|
false));
|
||||||
@ -1500,14 +1479,15 @@ public class ChallengesManager
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* This method returns LevelStatus object for given challenge level.
|
* This method returns LevelStatus object for given challenge level.
|
||||||
|
* @param uniqueId UUID of user who need to be validated.
|
||||||
* @param world World where level must be validated.
|
* @param world World where level must be validated.
|
||||||
* @param level Level that must be validated.
|
* @param level Level that must be validated.
|
||||||
* @param user User who need to be validated.
|
|
||||||
* @return LevelStatus of given level.
|
* @return LevelStatus of given level.
|
||||||
*/
|
*/
|
||||||
public LevelStatus getChallengeLevelStatus(UUID user, World world, ChallengeLevel level)
|
@Nullable
|
||||||
|
public LevelStatus getChallengeLevelStatus(UUID uniqueId, World world, ChallengeLevel level)
|
||||||
{
|
{
|
||||||
return this.getChallengeLevelStatus(this.getDataUniqueID(user, Util.getWorld(world)), world, level);
|
return this.getChallengeLevelStatus(this.getDataUniqueID(uniqueId, Util.getWorld(world)), world, level);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -1518,6 +1498,7 @@ public class ChallengesManager
|
|||||||
* @param world - World where levels should be searched.
|
* @param world - World where levels should be searched.
|
||||||
* @return Level status - how many challenges still to do on which level
|
* @return Level status - how many challenges still to do on which level
|
||||||
*/
|
*/
|
||||||
|
@NonNull
|
||||||
public List<LevelStatus> getAllChallengeLevelStatus(User user, World world)
|
public List<LevelStatus> getAllChallengeLevelStatus(User user, World world)
|
||||||
{
|
{
|
||||||
return this.islandWorldManager.getAddon(world).map(gameMode ->
|
return this.islandWorldManager.getAddon(world).map(gameMode ->
|
||||||
@ -1607,6 +1588,7 @@ public class ChallengesManager
|
|||||||
* @param name - unique name of challenge
|
* @param name - unique name of challenge
|
||||||
* @return - challenge or null if it does not exist
|
* @return - challenge or null if it does not exist
|
||||||
*/
|
*/
|
||||||
|
@Nullable
|
||||||
public Challenge getChallenge(String name)
|
public Challenge getChallenge(String name)
|
||||||
{
|
{
|
||||||
if (this.challengeCacheData.containsKey(name))
|
if (this.challengeCacheData.containsKey(name))
|
||||||
@ -1615,26 +1597,20 @@ public class ChallengesManager
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
System.out.println("Checking database");
|
|
||||||
// check database.
|
// check database.
|
||||||
if (this.challengeDatabase.objectExists(name))
|
if (this.challengeDatabase.objectExists(name))
|
||||||
{
|
{
|
||||||
System.out.println("Exists");
|
|
||||||
Challenge challenge = this.challengeDatabase.loadObject(name);
|
Challenge challenge = this.challengeDatabase.loadObject(name);
|
||||||
|
|
||||||
if (challenge != null)
|
if (challenge != null)
|
||||||
{
|
{
|
||||||
System.out.println("Loaded!");
|
|
||||||
this.challengeCacheData.put(name, challenge);
|
this.challengeCacheData.put(name, challenge);
|
||||||
return challenge;
|
return challenge;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
System.out.println("Error");
|
|
||||||
this.addon.logError("Tried to load NULL challenge object!");
|
this.addon.logError("Tried to load NULL challenge object!");
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
System.out.println("Not exists");
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1660,6 +1636,7 @@ public class ChallengesManager
|
|||||||
* @param requirements - requirements object, as it is not changeable anymore.
|
* @param requirements - requirements object, as it is not changeable anymore.
|
||||||
* @return Challenge that is currently created.
|
* @return Challenge that is currently created.
|
||||||
*/
|
*/
|
||||||
|
@Nullable
|
||||||
public Challenge createChallenge(String uniqueID, Challenge.ChallengeType type, Requirements requirements)
|
public Challenge createChallenge(String uniqueID, Challenge.ChallengeType type, Requirements requirements)
|
||||||
{
|
{
|
||||||
if (!this.containsChallenge(uniqueID))
|
if (!this.containsChallenge(uniqueID))
|
||||||
@ -1738,6 +1715,7 @@ public class ChallengesManager
|
|||||||
* @param challenge - challenge which level must be returned.
|
* @param challenge - challenge which level must be returned.
|
||||||
* @return - challenge level or null if it does not exist
|
* @return - challenge level or null if it does not exist
|
||||||
*/
|
*/
|
||||||
|
@Nullable
|
||||||
public ChallengeLevel getLevel(Challenge challenge)
|
public ChallengeLevel getLevel(Challenge challenge)
|
||||||
{
|
{
|
||||||
if (!challenge.getLevel().equals(FREE))
|
if (!challenge.getLevel().equals(FREE))
|
||||||
@ -1755,6 +1733,7 @@ public class ChallengesManager
|
|||||||
* @param name - unique name of challenge level
|
* @param name - unique name of challenge level
|
||||||
* @return - challenge level or null if it does not exist
|
* @return - challenge level or null if it does not exist
|
||||||
*/
|
*/
|
||||||
|
@Nullable
|
||||||
public ChallengeLevel getLevel(String name)
|
public ChallengeLevel getLevel(String name)
|
||||||
{
|
{
|
||||||
if (this.levelCacheData.containsKey(name))
|
if (this.levelCacheData.containsKey(name))
|
||||||
@ -1822,7 +1801,7 @@ public class ChallengesManager
|
|||||||
/**
|
/**
|
||||||
* This method adds given challenge to given challenge level.
|
* This method adds given challenge to given challenge level.
|
||||||
* @param newChallenge Challenge who must change owner.
|
* @param newChallenge Challenge who must change owner.
|
||||||
* @param newLevel Level who must add new challenge
|
* @param newLevel Level to add to - must exist already
|
||||||
*/
|
*/
|
||||||
public void addChallengeToLevel(Challenge newChallenge, ChallengeLevel newLevel)
|
public void addChallengeToLevel(Challenge newChallenge, ChallengeLevel newLevel)
|
||||||
{
|
{
|
||||||
@ -1838,7 +1817,7 @@ public class ChallengesManager
|
|||||||
{
|
{
|
||||||
ChallengeLevel oldLevel = this.getLevel(newChallenge.getLevel());
|
ChallengeLevel oldLevel = this.getLevel(newChallenge.getLevel());
|
||||||
|
|
||||||
if (!oldLevel.equals(newLevel))
|
if (oldLevel == null || !oldLevel.equals(newLevel))
|
||||||
{
|
{
|
||||||
this.removeChallengeFromLevel(newChallenge, newLevel);
|
this.removeChallengeFromLevel(newChallenge, newLevel);
|
||||||
newLevel.getChallenges().add(newChallenge.getUniqueId());
|
newLevel.getChallenges().add(newChallenge.getUniqueId());
|
||||||
@ -1873,6 +1852,7 @@ public class ChallengesManager
|
|||||||
* @param uniqueID - new ID for challenge level.
|
* @param uniqueID - new ID for challenge level.
|
||||||
* @return ChallengeLevel that is currently created.
|
* @return ChallengeLevel that is currently created.
|
||||||
*/
|
*/
|
||||||
|
@Nullable
|
||||||
public ChallengeLevel createLevel(String uniqueID, World world)
|
public ChallengeLevel createLevel(String uniqueID, World world)
|
||||||
{
|
{
|
||||||
if (!this.containsLevel(uniqueID))
|
if (!this.containsLevel(uniqueID))
|
||||||
|
@ -13,6 +13,7 @@ import org.bukkit.Material;
|
|||||||
import org.bukkit.World;
|
import org.bukkit.World;
|
||||||
import org.bukkit.entity.EntityType;
|
import org.bukkit.entity.EntityType;
|
||||||
import org.bukkit.inventory.ItemStack;
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
import org.eclipse.jdt.annotation.NonNull;
|
||||||
|
|
||||||
import com.google.gson.annotations.Expose;
|
import com.google.gson.annotations.Expose;
|
||||||
import com.google.gson.annotations.JsonAdapter;
|
import com.google.gson.annotations.JsonAdapter;
|
||||||
@ -717,7 +718,7 @@ public class Challenge implements DataObject
|
|||||||
* This method sets the level value.
|
* This method sets the level value.
|
||||||
* @param level the level new value.
|
* @param level the level new value.
|
||||||
*/
|
*/
|
||||||
public void setLevel(String level)
|
public void setLevel(@NonNull String level)
|
||||||
{
|
{
|
||||||
this.level = level;
|
this.level = level;
|
||||||
}
|
}
|
||||||
|
@ -1,12 +1,13 @@
|
|||||||
package world.bentobox.challenges;
|
package world.bentobox.challenges;
|
||||||
|
|
||||||
|
import static org.junit.Assert.assertEquals;
|
||||||
import static org.junit.Assert.assertFalse;
|
import static org.junit.Assert.assertFalse;
|
||||||
import static org.junit.Assert.assertNotNull;
|
import static org.junit.Assert.assertNotNull;
|
||||||
import static org.junit.Assert.assertNull;
|
import static org.junit.Assert.assertNull;
|
||||||
import static org.junit.Assert.assertTrue;
|
import static org.junit.Assert.assertTrue;
|
||||||
import static org.junit.Assert.fail;
|
|
||||||
import static org.mockito.ArgumentMatchers.any;
|
import static org.mockito.ArgumentMatchers.any;
|
||||||
import static org.mockito.ArgumentMatchers.anyString;
|
import static org.mockito.ArgumentMatchers.anyString;
|
||||||
|
import static org.mockito.ArgumentMatchers.eq;
|
||||||
import static org.mockito.Mockito.mock;
|
import static org.mockito.Mockito.mock;
|
||||||
import static org.mockito.Mockito.never;
|
import static org.mockito.Mockito.never;
|
||||||
import static org.mockito.Mockito.times;
|
import static org.mockito.Mockito.times;
|
||||||
@ -22,8 +23,11 @@ import java.io.FileWriter;
|
|||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.nio.file.Files;
|
import java.nio.file.Files;
|
||||||
import java.nio.file.Path;
|
import java.nio.file.Path;
|
||||||
|
import java.util.Arrays;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.Comparator;
|
import java.util.Comparator;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Optional;
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
@ -33,6 +37,8 @@ import org.bukkit.World;
|
|||||||
import org.bukkit.inventory.ItemFactory;
|
import org.bukkit.inventory.ItemFactory;
|
||||||
import org.bukkit.inventory.meta.ItemMeta;
|
import org.bukkit.inventory.meta.ItemMeta;
|
||||||
import org.bukkit.plugin.PluginManager;
|
import org.bukkit.plugin.PluginManager;
|
||||||
|
import org.eclipse.jdt.annotation.NonNull;
|
||||||
|
import org.eclipse.jdt.annotation.Nullable;
|
||||||
import org.junit.After;
|
import org.junit.After;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
@ -44,30 +50,42 @@ import org.powermock.modules.junit4.PowerMockRunner;
|
|||||||
import org.powermock.reflect.Whitebox;
|
import org.powermock.reflect.Whitebox;
|
||||||
|
|
||||||
import world.bentobox.bentobox.BentoBox;
|
import world.bentobox.bentobox.BentoBox;
|
||||||
|
import world.bentobox.bentobox.api.addons.AddonDescription;
|
||||||
|
import world.bentobox.bentobox.api.addons.GameModeAddon;
|
||||||
import world.bentobox.bentobox.api.user.User;
|
import world.bentobox.bentobox.api.user.User;
|
||||||
import world.bentobox.bentobox.database.DatabaseSetup.DatabaseType;
|
import world.bentobox.bentobox.database.DatabaseSetup.DatabaseType;
|
||||||
import world.bentobox.bentobox.managers.IslandWorldManager;
|
import world.bentobox.bentobox.managers.IslandWorldManager;
|
||||||
|
import world.bentobox.bentobox.managers.PlaceholdersManager;
|
||||||
|
import world.bentobox.bentobox.util.Util;
|
||||||
import world.bentobox.challenges.config.Settings;
|
import world.bentobox.challenges.config.Settings;
|
||||||
import world.bentobox.challenges.database.object.Challenge;
|
import world.bentobox.challenges.database.object.Challenge;
|
||||||
|
import world.bentobox.challenges.database.object.Challenge.ChallengeType;
|
||||||
import world.bentobox.challenges.database.object.ChallengeLevel;
|
import world.bentobox.challenges.database.object.ChallengeLevel;
|
||||||
|
import world.bentobox.challenges.events.ChallengeCompletedEvent;
|
||||||
|
import world.bentobox.challenges.events.ChallengeResetAllEvent;
|
||||||
|
import world.bentobox.challenges.events.ChallengeResetEvent;
|
||||||
|
import world.bentobox.challenges.events.LevelCompletedEvent;
|
||||||
|
import world.bentobox.challenges.utils.LevelStatus;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author tastybento
|
* @author tastybento
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
@SuppressWarnings("deprecation")
|
||||||
@RunWith(PowerMockRunner.class)
|
@RunWith(PowerMockRunner.class)
|
||||||
@PrepareForTest({Bukkit.class, BentoBox.class})
|
@PrepareForTest({Bukkit.class, BentoBox.class, Util.class})
|
||||||
public class ChallengesManagerTest {
|
public class ChallengesManagerTest {
|
||||||
|
|
||||||
|
// Constants
|
||||||
|
private static final String GAME_MODE_NAME = "BSkyBlock";
|
||||||
|
|
||||||
|
// Mocks
|
||||||
@Mock
|
@Mock
|
||||||
private ChallengesAddon addon;
|
private ChallengesAddon addon;
|
||||||
@Mock
|
@Mock
|
||||||
private Settings settings;
|
private Settings settings;
|
||||||
@Mock
|
@Mock
|
||||||
private IslandWorldManager iwm;
|
private IslandWorldManager iwm;
|
||||||
|
|
||||||
private ChallengesManager cm;
|
|
||||||
private File database;
|
|
||||||
@Mock
|
@Mock
|
||||||
private Server server;
|
private Server server;
|
||||||
@Mock
|
@Mock
|
||||||
@ -76,30 +94,50 @@ public class ChallengesManagerTest {
|
|||||||
private ItemFactory itemFactory;
|
private ItemFactory itemFactory;
|
||||||
@Mock
|
@Mock
|
||||||
private User user;
|
private User user;
|
||||||
private String uuid;
|
|
||||||
@Mock
|
@Mock
|
||||||
private World world;
|
private World world;
|
||||||
|
@Mock
|
||||||
|
private GameModeAddon gameModeAddon;
|
||||||
|
@Mock
|
||||||
|
private PlaceholdersManager plhm;
|
||||||
|
|
||||||
|
// Variable fields
|
||||||
|
private ChallengesManager cm;
|
||||||
|
private File database;
|
||||||
|
private String uuid;
|
||||||
|
private Challenge challenge;
|
||||||
|
private @NonNull ChallengeLevel level;
|
||||||
|
private UUID playerID = UUID.randomUUID();
|
||||||
|
private String cName;
|
||||||
|
private String levelName;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @throws java.lang.Exception
|
* @throws java.lang.Exception
|
||||||
*/
|
*/
|
||||||
@SuppressWarnings("deprecation")
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() throws Exception {
|
public void setUp() throws Exception {
|
||||||
// Set up plugin
|
// Set up plugin
|
||||||
BentoBox plugin = mock(BentoBox.class);
|
BentoBox plugin = mock(BentoBox.class);
|
||||||
Whitebox.setInternalState(BentoBox.class, "instance", plugin);
|
Whitebox.setInternalState(BentoBox.class, "instance", plugin);
|
||||||
when(addon.getPlugin()).thenReturn(plugin);
|
when(addon.getPlugin()).thenReturn(plugin);
|
||||||
|
|
||||||
|
// IWM
|
||||||
when(plugin.getIWM()).thenReturn(iwm);
|
when(plugin.getIWM()).thenReturn(iwm);
|
||||||
when(iwm.inWorld(any(World.class))).thenReturn(true);
|
when(iwm.inWorld(any(World.class))).thenReturn(true);
|
||||||
|
|
||||||
|
// Placeholders
|
||||||
|
when(plugin.getPlaceholdersManager()).thenReturn(plhm);
|
||||||
|
|
||||||
// Settings for Database
|
// Settings for Database
|
||||||
world.bentobox.bentobox.Settings s = mock(world.bentobox.bentobox.Settings.class);
|
world.bentobox.bentobox.Settings s = mock(world.bentobox.bentobox.Settings.class);
|
||||||
when(plugin.getSettings()).thenReturn(s);
|
when(plugin.getSettings()).thenReturn(s);
|
||||||
when(s.getDatabaseType()).thenReturn(DatabaseType.JSON);
|
when(s.getDatabaseType()).thenReturn(DatabaseType.JSON);
|
||||||
|
|
||||||
// Settings
|
// Addon Settings
|
||||||
when(addon.getChallengesSettings()).thenReturn(settings);
|
when(addon.getChallengesSettings()).thenReturn(settings);
|
||||||
|
when(settings.isStoreHistory()).thenReturn(true);
|
||||||
|
when(settings.getLifeSpan()).thenReturn(10);
|
||||||
|
|
||||||
// Database
|
// Database
|
||||||
database = new File("database");
|
database = new File("database");
|
||||||
tearDown();
|
tearDown();
|
||||||
@ -117,6 +155,37 @@ public class ChallengesManagerTest {
|
|||||||
when(unsafe.getDataVersion()).thenReturn(777);
|
when(unsafe.getDataVersion()).thenReturn(777);
|
||||||
when(Bukkit.getUnsafe()).thenReturn(unsafe);
|
when(Bukkit.getUnsafe()).thenReturn(unsafe);
|
||||||
|
|
||||||
|
// Challenge
|
||||||
|
challenge = new Challenge();
|
||||||
|
uuid = UUID.randomUUID().toString();
|
||||||
|
challenge.setUniqueId(GAME_MODE_NAME + "_" + uuid);
|
||||||
|
challenge.setFriendlyName("name");
|
||||||
|
challenge.setLevel(GAME_MODE_NAME + "_novice");
|
||||||
|
challenge.setDescription(Collections.singletonList("A description"));
|
||||||
|
|
||||||
|
// Challenge Level
|
||||||
|
level = new ChallengeLevel();
|
||||||
|
levelName = GAME_MODE_NAME + "_novice";
|
||||||
|
level.setUniqueId(levelName);
|
||||||
|
level.setFriendlyName("Novice");
|
||||||
|
|
||||||
|
// User
|
||||||
|
when(user.getUniqueId()).thenReturn(playerID);
|
||||||
|
|
||||||
|
// Util
|
||||||
|
PowerMockito.mockStatic(Util.class);
|
||||||
|
when(Util.getWorld(any())).thenReturn(world);
|
||||||
|
|
||||||
|
// Addon
|
||||||
|
AddonDescription desc = new AddonDescription.Builder("main", GAME_MODE_NAME, "1.0").build();
|
||||||
|
when(gameModeAddon.getDescription()).thenReturn(desc);
|
||||||
|
Optional<GameModeAddon> opAddon = Optional.of(gameModeAddon);
|
||||||
|
when(iwm.getAddon(any())).thenReturn(opAddon);
|
||||||
|
|
||||||
|
// Challenge name
|
||||||
|
cName = GAME_MODE_NAME + "_" + uuid;
|
||||||
|
|
||||||
|
// Class under test
|
||||||
cm = new ChallengesManager(addon);
|
cm = new ChallengesManager(addon);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -127,7 +196,6 @@ public class ChallengesManagerTest {
|
|||||||
public void tearDown() throws Exception {
|
public void tearDown() throws Exception {
|
||||||
// Clean up JSON database
|
// Clean up JSON database
|
||||||
// Clean up file system
|
// Clean up file system
|
||||||
|
|
||||||
if (database.exists()) {
|
if (database.exists()) {
|
||||||
Files.walk(database.toPath())
|
Files.walk(database.toPath())
|
||||||
.sorted(Comparator.reverseOrder())
|
.sorted(Comparator.reverseOrder())
|
||||||
@ -139,9 +207,10 @@ public class ChallengesManagerTest {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Test method for {@link world.bentobox.challenges.ChallengesManager#load()}.
|
* Test method for {@link world.bentobox.challenges.ChallengesManager#load()}.
|
||||||
|
* @throws InterruptedException
|
||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testLoad() {
|
public void testLoad() throws InterruptedException {
|
||||||
verify(addon).log("Loading challenges...");
|
verify(addon).log("Loading challenges...");
|
||||||
verify(addon, never()).logError(anyString());
|
verify(addon, never()).logError(anyString());
|
||||||
this.testSaveLevel();
|
this.testSaveLevel();
|
||||||
@ -149,31 +218,117 @@ public class ChallengesManagerTest {
|
|||||||
cm.load();
|
cm.load();
|
||||||
verify(addon, times(2)).log("Loading challenges...");
|
verify(addon, times(2)).log("Loading challenges...");
|
||||||
verify(addon, never()).logError(anyString());
|
verify(addon, never()).logError(anyString());
|
||||||
assertTrue(cm.containsChallenge(uuid));
|
assertTrue(cm.containsChallenge(cName));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Test method for {@link world.bentobox.challenges.ChallengesManager#reload()}.
|
* Test method for {@link world.bentobox.challenges.ChallengesManager#reload()}.
|
||||||
|
* @throws InterruptedException
|
||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testReload() {
|
public void testReload() throws InterruptedException {
|
||||||
fail("Not yet implemented");
|
cm.reload();
|
||||||
|
verify(addon).log("Reloading challenges...");
|
||||||
|
this.testSaveLevel();
|
||||||
|
this.testSaveChallenge();
|
||||||
|
cm.reload();
|
||||||
|
verify(addon, times(2)).log("Reloading challenges...");
|
||||||
|
verify(addon, never()).logError(anyString());
|
||||||
|
assertTrue(cm.containsChallenge(cName));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Test method for {@link world.bentobox.challenges.ChallengesManager#loadChallenge(world.bentobox.challenges.database.object.Challenge, boolean, world.bentobox.bentobox.api.user.User, boolean)}.
|
* Test method for {@link world.bentobox.challenges.ChallengesManager#loadChallenge(world.bentobox.challenges.database.object.Challenge, boolean, world.bentobox.bentobox.api.user.User, boolean)}.
|
||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testLoadChallenge() {
|
public void testLoadChallengeNoOverwriteSilent() {
|
||||||
fail("Not yet implemented");
|
// load once
|
||||||
|
assertTrue(cm.loadChallenge(challenge, false, user, true));
|
||||||
|
// load twice - no overwrite
|
||||||
|
assertFalse(cm.loadChallenge(challenge, false, user, true));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test method for {@link world.bentobox.challenges.ChallengesManager#loadChallenge(world.bentobox.challenges.database.object.Challenge, boolean, world.bentobox.bentobox.api.user.User, boolean)}.
|
||||||
|
*/
|
||||||
|
@Test
|
||||||
|
public void testLoadChallengeNoOverwriteNotSilent() {
|
||||||
|
// load once
|
||||||
|
assertTrue(cm.loadChallenge(challenge, false, user, true));
|
||||||
|
// load twice - no overwrite, not silent
|
||||||
|
assertFalse(cm.loadChallenge(challenge, false, user, false));
|
||||||
|
verify(user).sendMessage("challenges.messages.load-skipping", "[value]", "name");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test method for {@link world.bentobox.challenges.ChallengesManager#loadChallenge(world.bentobox.challenges.database.object.Challenge, boolean, world.bentobox.bentobox.api.user.User, boolean)}.
|
||||||
|
*/
|
||||||
|
@Test
|
||||||
|
public void testLoadChallengeOverwriteSilent() {
|
||||||
|
// load once
|
||||||
|
assertTrue(cm.loadChallenge(challenge, false, user, true));
|
||||||
|
// overwrite
|
||||||
|
assertTrue(cm.loadChallenge(challenge, true, user, true));
|
||||||
|
verify(user, never()).sendMessage(anyString(), anyString(), anyString());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test method for {@link world.bentobox.challenges.ChallengesManager#loadChallenge(world.bentobox.challenges.database.object.Challenge, boolean, world.bentobox.bentobox.api.user.User, boolean)}.
|
||||||
|
*/
|
||||||
|
@Test
|
||||||
|
public void testLoadChallengeOverwriteNotSilent() {
|
||||||
|
// load once
|
||||||
|
assertTrue(cm.loadChallenge(challenge, false, user, true));
|
||||||
|
// overwrite not silent
|
||||||
|
assertTrue(cm.loadChallenge(challenge, true, user, false));
|
||||||
|
verify(user).sendMessage("challenges.messages.load-overwriting", "[value]", "name");
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Test method for {@link world.bentobox.challenges.ChallengesManager#loadLevel(world.bentobox.challenges.database.object.ChallengeLevel, boolean, world.bentobox.bentobox.api.user.User, boolean)}.
|
* Test method for {@link world.bentobox.challenges.ChallengesManager#loadLevel(world.bentobox.challenges.database.object.ChallengeLevel, boolean, world.bentobox.bentobox.api.user.User, boolean)}.
|
||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testLoadLevel() {
|
public void testLoadLevelNoOverwriteSilent() {
|
||||||
fail("Not yet implemented");
|
// load once
|
||||||
|
assertTrue(cm.loadLevel(level, false, user, true));
|
||||||
|
// load twice - no overwrite
|
||||||
|
assertFalse(cm.loadLevel(level, false, user, true));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test method for {@link world.bentobox.challenges.ChallengesManager#loadLevel(world.bentobox.challenges.database.object.ChallengeLevel, boolean, world.bentobox.bentobox.api.user.User, boolean)}.
|
||||||
|
*/
|
||||||
|
@Test
|
||||||
|
public void testLoadLevelNoOverwriteNotSilent() {
|
||||||
|
// load once
|
||||||
|
assertTrue(cm.loadLevel(level, false, user, true));
|
||||||
|
// load twice - no overwrite, not silent
|
||||||
|
assertFalse(cm.loadLevel(level, false, user, false));
|
||||||
|
verify(user).sendMessage("challenges.messages.load-skipping", "[value]", "Novice");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test method for {@link world.bentobox.challenges.ChallengesManager#loadLevel(world.bentobox.challenges.database.object.ChallengeLevel, boolean, world.bentobox.bentobox.api.user.User, boolean)}.
|
||||||
|
*/
|
||||||
|
@Test
|
||||||
|
public void testLoadLevelOverwriteSilent() {
|
||||||
|
// load once
|
||||||
|
assertTrue(cm.loadLevel(level, false, user, true));
|
||||||
|
// overwrite
|
||||||
|
assertTrue(cm.loadLevel(level, true, user, true));
|
||||||
|
verify(user, never()).sendMessage(anyString(), anyString(), anyString());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test method for {@link world.bentobox.challenges.ChallengesManager#loadLevel(world.bentobox.challenges.database.object.ChallengeLevel, boolean, world.bentobox.bentobox.api.user.User, boolean)}.
|
||||||
|
*/
|
||||||
|
@Test
|
||||||
|
public void testLoadLevelOverwriteNotSilent() {
|
||||||
|
// load once
|
||||||
|
assertTrue(cm.loadLevel(level, false, user, true));
|
||||||
|
// overwrite not silent
|
||||||
|
assertTrue(cm.loadLevel(level, true, user, false));
|
||||||
|
verify(user).sendMessage("challenges.messages.load-overwriting", "[value]", "Novice");
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -181,23 +336,62 @@ public class ChallengesManagerTest {
|
|||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testRemoveFromCache() {
|
public void testRemoveFromCache() {
|
||||||
fail("Not yet implemented");
|
cm.removeFromCache(playerID);
|
||||||
|
verify(settings).isStoreAsIslandData();
|
||||||
|
// TODO there should be a test where isStoreAsIslandData returns true
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Test method for {@link world.bentobox.challenges.ChallengesManager#wipeDatabase(boolean)}.
|
* Test method for {@link world.bentobox.challenges.ChallengesManager#wipeDatabase(boolean)}.
|
||||||
|
* @throws InterruptedException
|
||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testWipeDatabase() {
|
public void testWipeDatabase() throws InterruptedException {
|
||||||
fail("Not yet implemented");
|
// Create some database
|
||||||
|
this.testLoad();
|
||||||
|
|
||||||
|
// Verify file exists
|
||||||
|
File chDir = new File(database, "Challenge");
|
||||||
|
File check = new File(chDir, cName + ".json");
|
||||||
|
assertTrue(check.exists());
|
||||||
|
|
||||||
|
File lvDir = new File(database, "ChallengeLevel");
|
||||||
|
File checkLv = new File(lvDir, levelName + ".json");
|
||||||
|
assertTrue(checkLv.exists());
|
||||||
|
|
||||||
|
cm.setChallengeComplete(user, world, challenge, 20);
|
||||||
|
//cm.save();
|
||||||
|
File plData = new File(database, "ChallengesPlayerData");
|
||||||
|
File checkPd = new File(plData, playerID.toString() + ".json");
|
||||||
|
assertTrue(checkPd.exists());
|
||||||
|
|
||||||
|
// Wipe it
|
||||||
|
cm.wipeDatabase(false);
|
||||||
|
|
||||||
|
// Verify
|
||||||
|
assertFalse(check.exists());
|
||||||
|
assertFalse(checkLv.exists());
|
||||||
|
assertTrue(checkPd.exists());
|
||||||
|
|
||||||
|
cm.wipeDatabase(true);
|
||||||
|
assertFalse(checkPd.exists());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Test method for {@link world.bentobox.challenges.ChallengesManager#wipePlayers()}.
|
* Test method for {@link world.bentobox.challenges.ChallengesManager#wipePlayers()}.
|
||||||
|
* @throws InterruptedException
|
||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testWipePlayers() {
|
public void testWipePlayers() throws InterruptedException {
|
||||||
fail("Not yet implemented");
|
this.testLoad();
|
||||||
|
cm.setChallengeComplete(user, world, challenge, 20);
|
||||||
|
cm.save();
|
||||||
|
File plData = new File(database, "ChallengesPlayerData");
|
||||||
|
Arrays.stream(plData.listFiles()).map(f -> f.getName()).forEach(System.out::println);
|
||||||
|
File checkLv = new File(plData, playerID.toString() + ".json");
|
||||||
|
assertTrue(checkLv.exists());
|
||||||
|
cm.wipePlayers();
|
||||||
|
assertFalse(checkLv.exists());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -205,7 +399,7 @@ public class ChallengesManagerTest {
|
|||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testMigrateDatabase() {
|
public void testMigrateDatabase() {
|
||||||
fail("Not yet implemented");
|
cm.migrateDatabase(user, world);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -213,24 +407,21 @@ public class ChallengesManagerTest {
|
|||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testSave() {
|
public void testSave() {
|
||||||
fail("Not yet implemented");
|
cm.save();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Test method for {@link world.bentobox.challenges.ChallengesManager#saveChallenge(world.bentobox.challenges.database.object.Challenge)}.
|
* Test method for {@link world.bentobox.challenges.ChallengesManager#saveChallenge(world.bentobox.challenges.database.object.Challenge)}.
|
||||||
|
* @throws InterruptedException
|
||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testSaveChallenge() {
|
public void testSaveChallenge() throws InterruptedException {
|
||||||
Challenge challenge = new Challenge();
|
// Async - may not happen quickly
|
||||||
uuid = UUID.randomUUID().toString();
|
|
||||||
challenge.setUniqueId(uuid);
|
|
||||||
challenge.setFriendlyName("name");
|
|
||||||
challenge.setLevel("novice");
|
|
||||||
challenge.setDescription(Collections.singletonList("A description"));
|
|
||||||
cm.saveChallenge(challenge);
|
cm.saveChallenge(challenge);
|
||||||
|
Thread.sleep(500);
|
||||||
File chDir = new File(database, "Challenge");
|
File chDir = new File(database, "Challenge");
|
||||||
assertTrue(chDir.exists());
|
assertTrue(chDir.exists());
|
||||||
File check = new File(chDir, uuid + ".json");
|
File check = new File(chDir, cName + ".json");
|
||||||
assertTrue(check.exists());
|
assertTrue(check.exists());
|
||||||
// Remove icon becauseit has mockito meta in it
|
// Remove icon becauseit has mockito meta in it
|
||||||
removeLine(check);
|
removeLine(check);
|
||||||
@ -253,10 +444,8 @@ public class ChallengesManagerTest {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
} catch (FileNotFoundException e) {
|
} catch (FileNotFoundException e) {
|
||||||
// TODO Auto-generated catch block
|
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
// TODO Auto-generated catch block
|
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -264,16 +453,15 @@ public class ChallengesManagerTest {
|
|||||||
}
|
}
|
||||||
/**
|
/**
|
||||||
* Test method for {@link world.bentobox.challenges.ChallengesManager#saveLevel(world.bentobox.challenges.database.object.ChallengeLevel)}.
|
* Test method for {@link world.bentobox.challenges.ChallengesManager#saveLevel(world.bentobox.challenges.database.object.ChallengeLevel)}.
|
||||||
|
* @throws InterruptedException
|
||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testSaveLevel() {
|
public void testSaveLevel() throws InterruptedException {
|
||||||
ChallengeLevel level = new ChallengeLevel();
|
|
||||||
level.setUniqueId("novice");
|
|
||||||
level.setFriendlyName("name");
|
|
||||||
cm.saveLevel(level);
|
cm.saveLevel(level);
|
||||||
|
Thread.sleep(500);
|
||||||
File chDir = new File(database, "ChallengeLevel");
|
File chDir = new File(database, "ChallengeLevel");
|
||||||
assertTrue(chDir.exists());
|
assertTrue(chDir.exists());
|
||||||
File check = new File(chDir, "novice.json");
|
File check = new File(chDir, GAME_MODE_NAME + "_novice.json");
|
||||||
assertTrue(check.exists());
|
assertTrue(check.exists());
|
||||||
// Remove icon becauseit has mockito meta in it
|
// Remove icon becauseit has mockito meta in it
|
||||||
removeLine(check);
|
removeLine(check);
|
||||||
@ -284,7 +472,7 @@ public class ChallengesManagerTest {
|
|||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testIsChallengeCompleteUserWorldChallenge() {
|
public void testIsChallengeCompleteUserWorldChallenge() {
|
||||||
fail("Not yet implemented");
|
assertFalse(cm.isChallengeComplete(user, world, challenge));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -292,7 +480,7 @@ public class ChallengesManagerTest {
|
|||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testIsChallengeCompleteUUIDWorldChallenge() {
|
public void testIsChallengeCompleteUUIDWorldChallenge() {
|
||||||
fail("Not yet implemented");
|
assertFalse(cm.isChallengeComplete(playerID, world, challenge));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -300,7 +488,7 @@ public class ChallengesManagerTest {
|
|||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testIsChallengeCompleteUUIDWorldString() {
|
public void testIsChallengeCompleteUUIDWorldString() {
|
||||||
fail("Not yet implemented");
|
assertFalse(cm.isChallengeComplete(playerID, world, "Novice"));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -308,7 +496,9 @@ public class ChallengesManagerTest {
|
|||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testSetChallengeCompleteUserWorldChallengeInt() {
|
public void testSetChallengeCompleteUserWorldChallengeInt() {
|
||||||
fail("Not yet implemented");
|
cm.setChallengeComplete(user, world, challenge, 3);
|
||||||
|
assertTrue(cm.isChallengeComplete(user, world, challenge));
|
||||||
|
verify(pim).callEvent(any(ChallengeCompletedEvent.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -316,7 +506,9 @@ public class ChallengesManagerTest {
|
|||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testSetChallengeCompleteUUIDWorldChallengeInt() {
|
public void testSetChallengeCompleteUUIDWorldChallengeInt() {
|
||||||
fail("Not yet implemented");
|
cm.setChallengeComplete(playerID, world, challenge, 3);
|
||||||
|
assertTrue(cm.isChallengeComplete(playerID, world, challenge));
|
||||||
|
verify(pim).callEvent(any(ChallengeCompletedEvent.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -324,7 +516,10 @@ public class ChallengesManagerTest {
|
|||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testSetChallengeCompleteUUIDWorldChallengeUUID() {
|
public void testSetChallengeCompleteUUIDWorldChallengeUUID() {
|
||||||
fail("Not yet implemented");
|
UUID adminID = UUID.randomUUID();
|
||||||
|
cm.setChallengeComplete(playerID, world, challenge, adminID);
|
||||||
|
assertTrue(cm.isChallengeComplete(playerID, world, challenge));
|
||||||
|
verify(pim).callEvent(any(ChallengeCompletedEvent.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -332,7 +527,11 @@ public class ChallengesManagerTest {
|
|||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testResetChallenge() {
|
public void testResetChallenge() {
|
||||||
fail("Not yet implemented");
|
cm.setChallengeComplete(user, world, challenge, 3);
|
||||||
|
assertTrue(cm.isChallengeComplete(user, world, challenge));
|
||||||
|
cm.resetChallenge(playerID, world, challenge, playerID);
|
||||||
|
assertFalse(cm.isChallengeComplete(user, world, challenge));
|
||||||
|
verify(pim).callEvent(any(ChallengeResetEvent.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -340,7 +539,11 @@ public class ChallengesManagerTest {
|
|||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testResetAllChallengesUserWorld() {
|
public void testResetAllChallengesUserWorld() {
|
||||||
fail("Not yet implemented");
|
cm.setChallengeComplete(user, world, challenge, 3);
|
||||||
|
assertTrue(cm.isChallengeComplete(user, world, challenge));
|
||||||
|
cm.resetAllChallenges(user, world);
|
||||||
|
assertFalse(cm.isChallengeComplete(user, world, challenge));
|
||||||
|
verify(pim).callEvent(any(ChallengeResetAllEvent.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -348,7 +551,11 @@ public class ChallengesManagerTest {
|
|||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testResetAllChallengesUUIDWorldUUID() {
|
public void testResetAllChallengesUUIDWorldUUID() {
|
||||||
fail("Not yet implemented");
|
cm.setChallengeComplete(user, world, challenge, 3);
|
||||||
|
assertTrue(cm.isChallengeComplete(user, world, challenge));
|
||||||
|
cm.resetAllChallenges(playerID, world, playerID);
|
||||||
|
assertFalse(cm.isChallengeComplete(user, world, challenge));
|
||||||
|
verify(pim).callEvent(any(ChallengeResetAllEvent.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -356,7 +563,9 @@ public class ChallengesManagerTest {
|
|||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testGetChallengeTimesUserWorldChallenge() {
|
public void testGetChallengeTimesUserWorldChallenge() {
|
||||||
fail("Not yet implemented");
|
assertEquals(0L, cm.getChallengeTimes(user, world, challenge));
|
||||||
|
cm.setChallengeComplete(user, world, challenge, 6);
|
||||||
|
assertEquals(6L, cm.getChallengeTimes(user, world, challenge));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -364,7 +573,9 @@ public class ChallengesManagerTest {
|
|||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testGetChallengeTimesUserWorldString() {
|
public void testGetChallengeTimesUserWorldString() {
|
||||||
fail("Not yet implemented");
|
assertEquals(0L, cm.getChallengeTimes(user, world, cName));
|
||||||
|
cm.setChallengeComplete(user, world, challenge, 6);
|
||||||
|
assertEquals(6L, cm.getChallengeTimes(user, world, cName));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -372,7 +583,7 @@ public class ChallengesManagerTest {
|
|||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testIsLevelCompleted() {
|
public void testIsLevelCompleted() {
|
||||||
fail("Not yet implemented");
|
assertFalse(cm.isLevelCompleted(user, world, level));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -380,7 +591,9 @@ public class ChallengesManagerTest {
|
|||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testIsLevelUnlocked() {
|
public void testIsLevelUnlocked() {
|
||||||
fail("Not yet implemented");
|
assertFalse(cm.isLevelUnlocked(user, world, level));
|
||||||
|
this.testLoadLevelNoOverwriteSilent();
|
||||||
|
assertTrue(cm.isLevelUnlocked(user, world, level));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -388,7 +601,10 @@ public class ChallengesManagerTest {
|
|||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testSetLevelComplete() {
|
public void testSetLevelComplete() {
|
||||||
fail("Not yet implemented");
|
assertFalse(cm.isLevelCompleted(user, world, level));
|
||||||
|
cm.setLevelComplete(user, world, level);
|
||||||
|
assertTrue(cm.isLevelCompleted(user, world, level));
|
||||||
|
verify(pim).callEvent(any(LevelCompletedEvent.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -396,7 +612,7 @@ public class ChallengesManagerTest {
|
|||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testValidateLevelCompletion() {
|
public void testValidateLevelCompletion() {
|
||||||
fail("Not yet implemented");
|
assertTrue(cm.validateLevelCompletion(user, world, level));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -404,7 +620,14 @@ public class ChallengesManagerTest {
|
|||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testGetChallengeLevelStatus() {
|
public void testGetChallengeLevelStatus() {
|
||||||
fail("Not yet implemented");
|
this.testLoadLevelNoOverwriteSilent();
|
||||||
|
LevelStatus cls = cm.getChallengeLevelStatus(playerID, world, level);
|
||||||
|
assertTrue(cls.getNumberOfChallengesStillToDo() == 0);
|
||||||
|
assertEquals(level, cls.getLevel());
|
||||||
|
assertTrue(cls.isComplete());
|
||||||
|
assertTrue(cls.isUnlocked());
|
||||||
|
assertEquals("BSkyBlock_novice", cls.getLevel().getUniqueId());
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -412,7 +635,15 @@ public class ChallengesManagerTest {
|
|||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testGetAllChallengeLevelStatus() {
|
public void testGetAllChallengeLevelStatus() {
|
||||||
fail("Not yet implemented");
|
this.testLoadLevelNoOverwriteSilent();
|
||||||
|
List<LevelStatus> list = cm.getAllChallengeLevelStatus(user, world);
|
||||||
|
assertTrue(list.size() == 1);
|
||||||
|
LevelStatus cls = list.get(0);
|
||||||
|
assertTrue(cls.getNumberOfChallengesStillToDo() == 0);
|
||||||
|
assertEquals(level, cls.getLevel());
|
||||||
|
assertTrue(cls.isComplete());
|
||||||
|
assertTrue(cls.isUnlocked());
|
||||||
|
assertEquals("BSkyBlock_novice", cls.getLevel().getUniqueId());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -420,7 +651,12 @@ public class ChallengesManagerTest {
|
|||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testGetAllChallengesNames() {
|
public void testGetAllChallengesNames() {
|
||||||
fail("Not yet implemented");
|
assertTrue(cm.getAllChallengesNames(world).isEmpty());
|
||||||
|
cm.saveChallenge(challenge);
|
||||||
|
cm.loadChallenge(challenge, false, user, true);
|
||||||
|
List<String> list = cm.getAllChallengesNames(world);
|
||||||
|
assertFalse(list.isEmpty());
|
||||||
|
assertEquals(cName, list.get(0));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -428,7 +664,12 @@ public class ChallengesManagerTest {
|
|||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testGetAllChallenges() {
|
public void testGetAllChallenges() {
|
||||||
fail("Not yet implemented");
|
assertTrue(cm.getAllChallenges(world).isEmpty());
|
||||||
|
cm.saveChallenge(challenge);
|
||||||
|
cm.loadChallenge(challenge, false, user, true);
|
||||||
|
List<Challenge> list = cm.getAllChallenges(world);
|
||||||
|
assertFalse(list.isEmpty());
|
||||||
|
assertEquals(challenge, list.get(0));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -436,26 +677,50 @@ public class ChallengesManagerTest {
|
|||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testGetFreeChallenges() {
|
public void testGetFreeChallenges() {
|
||||||
fail("Not yet implemented");
|
// Empty
|
||||||
|
assertTrue(cm.getFreeChallenges(world).isEmpty());
|
||||||
|
// One normal
|
||||||
|
cm.saveChallenge(challenge);
|
||||||
|
cm.loadChallenge(challenge, false, user, true);
|
||||||
|
assertTrue(cm.getFreeChallenges(world).isEmpty());
|
||||||
|
// One free
|
||||||
|
challenge.setLevel("");
|
||||||
|
cm.saveChallenge(challenge);
|
||||||
|
cm.loadChallenge(challenge, false, user, true);
|
||||||
|
List<Challenge> list = cm.getFreeChallenges(world);
|
||||||
|
assertFalse(list.isEmpty());
|
||||||
|
assertEquals(challenge, list.get(0));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Test method for {@link world.bentobox.challenges.ChallengesManager#getLevelChallenges(world.bentobox.challenges.database.object.ChallengeLevel)}.
|
* Test method for {@link world.bentobox.challenges.ChallengesManager#getLevelChallenges(world.bentobox.challenges.database.object.ChallengeLevel)}.
|
||||||
|
* @throws InterruptedException
|
||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testGetLevelChallenges() {
|
public void testGetLevelChallenges() throws InterruptedException {
|
||||||
fail("Not yet implemented");
|
assertTrue(cm.getLevelChallenges(level).isEmpty());
|
||||||
|
// make some challenges
|
||||||
|
this.testSaveLevel();
|
||||||
|
this.testSaveChallenge();
|
||||||
|
level.setChallenges(Collections.singleton(challenge.getUniqueId()));
|
||||||
|
// Test again
|
||||||
|
List<Challenge> list = cm.getLevelChallenges(level);
|
||||||
|
assertFalse(list.isEmpty());
|
||||||
|
assertEquals(challenge, list.get(0));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Test method for {@link world.bentobox.challenges.ChallengesManager#getChallenge(java.lang.String)}.
|
* Test method for {@link world.bentobox.challenges.ChallengesManager#getChallenge(java.lang.String)}.
|
||||||
|
* @throws InterruptedException
|
||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testGetChallenge() {
|
public void testGetChallenge() throws InterruptedException {
|
||||||
assertNull(cm.getChallenge("name"));
|
assertNull(cm.getChallenge(cName));
|
||||||
this.testSaveLevel();
|
this.testSaveLevel();
|
||||||
this.testSaveChallenge();
|
this.testSaveChallenge();
|
||||||
assertNotNull(cm.getChallenge(uuid));
|
Challenge ch = cm.getChallenge(cName);
|
||||||
|
assertNotNull(ch);
|
||||||
|
assertEquals(cName, ch.getUniqueId());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -471,15 +736,27 @@ public class ChallengesManagerTest {
|
|||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testCreateChallenge() {
|
public void testCreateChallenge() {
|
||||||
fail("Not yet implemented");
|
@Nullable
|
||||||
|
Challenge ch = cm.createChallenge("newChal", ChallengeType.ISLAND, null);
|
||||||
|
assertEquals(ChallengeType.ISLAND, ch.getChallengeType());
|
||||||
|
assertEquals("newChal", ch.getUniqueId());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Test method for {@link world.bentobox.challenges.ChallengesManager#deleteChallenge(world.bentobox.challenges.database.object.Challenge)}.
|
* Test method for {@link world.bentobox.challenges.ChallengesManager#deleteChallenge(world.bentobox.challenges.database.object.Challenge)}.
|
||||||
|
* @throws InterruptedException
|
||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testDeleteChallenge() {
|
public void testDeleteChallenge() throws InterruptedException {
|
||||||
fail("Not yet implemented");
|
this.testSaveLevel();
|
||||||
|
this.testSaveChallenge();
|
||||||
|
Challenge ch = cm.getChallenge(cName);
|
||||||
|
assertNotNull(ch);
|
||||||
|
assertEquals(cName, ch.getUniqueId());
|
||||||
|
cm.deleteChallenge(challenge);
|
||||||
|
ch = cm.getChallenge(cName);
|
||||||
|
assertNull(ch);
|
||||||
|
verify(plhm).unregisterPlaceholder(eq("challenges_challenge_repetition_count_" + cName));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -487,7 +764,10 @@ public class ChallengesManagerTest {
|
|||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testGetLevels() {
|
public void testGetLevels() {
|
||||||
fail("Not yet implemented");
|
this.testGetLevelString();
|
||||||
|
List<ChallengeLevel> lvs = cm.getLevels(world);
|
||||||
|
assertFalse(lvs.isEmpty());
|
||||||
|
assertEquals(level, lvs.get(0));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -495,7 +775,8 @@ public class ChallengesManagerTest {
|
|||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testGetLevelChallenge() {
|
public void testGetLevelChallenge() {
|
||||||
fail("Not yet implemented");
|
this.testGetLevelString();
|
||||||
|
assertEquals(level, cm.getLevel(challenge));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -503,7 +784,10 @@ public class ChallengesManagerTest {
|
|||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testGetLevelString() {
|
public void testGetLevelString() {
|
||||||
fail("Not yet implemented");
|
assertNull(cm.getLevel("dss"));
|
||||||
|
cm.saveLevel(level);
|
||||||
|
cm.loadLevel(level, false, user, true);
|
||||||
|
assertEquals(level, cm.getLevel(levelName));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -511,23 +795,33 @@ public class ChallengesManagerTest {
|
|||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testContainsLevel() {
|
public void testContainsLevel() {
|
||||||
fail("Not yet implemented");
|
this.testGetLevelString();
|
||||||
|
assertFalse(cm.containsLevel("sdsd"));
|
||||||
|
assertTrue(cm.containsLevel(levelName));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Test method for {@link world.bentobox.challenges.ChallengesManager#addChallengeToLevel(world.bentobox.challenges.database.object.Challenge, world.bentobox.challenges.database.object.ChallengeLevel)}.
|
* Test method for {@link world.bentobox.challenges.ChallengesManager#addChallengeToLevel(world.bentobox.challenges.database.object.Challenge, world.bentobox.challenges.database.object.ChallengeLevel)}.
|
||||||
|
* @throws InterruptedException
|
||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testAddChallengeToLevel() {
|
public void testAddChallengeToLevel() throws InterruptedException {
|
||||||
fail("Not yet implemented");
|
this.testLoad();
|
||||||
|
cm.deleteChallenge(challenge);
|
||||||
|
assertFalse(cm.containsChallenge(cName));
|
||||||
|
cm.addChallengeToLevel(challenge, level);
|
||||||
|
assertEquals(level, cm.getLevel(challenge));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Test method for {@link world.bentobox.challenges.ChallengesManager#removeChallengeFromLevel(world.bentobox.challenges.database.object.Challenge, world.bentobox.challenges.database.object.ChallengeLevel)}.
|
* Test method for {@link world.bentobox.challenges.ChallengesManager#removeChallengeFromLevel(world.bentobox.challenges.database.object.Challenge, world.bentobox.challenges.database.object.ChallengeLevel)}.
|
||||||
|
* @throws InterruptedException
|
||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testRemoveChallengeFromLevel() {
|
public void testRemoveChallengeFromLevel() throws InterruptedException {
|
||||||
fail("Not yet implemented");
|
this.testAddChallengeToLevel();
|
||||||
|
cm.removeChallengeFromLevel(challenge, level);
|
||||||
|
assertFalse(cm.containsChallenge(cName));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -535,31 +829,44 @@ public class ChallengesManagerTest {
|
|||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testCreateLevel() {
|
public void testCreateLevel() {
|
||||||
fail("Not yet implemented");
|
@Nullable
|
||||||
|
ChallengeLevel cl = cm.createLevel("Expert", world);
|
||||||
|
assertEquals("Expert", cl.getUniqueId());
|
||||||
|
assertEquals(world.getName(), cl.getWorld());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Test method for {@link world.bentobox.challenges.ChallengesManager#deleteChallengeLevel(world.bentobox.challenges.database.object.ChallengeLevel)}.
|
* Test method for {@link world.bentobox.challenges.ChallengesManager#deleteChallengeLevel(world.bentobox.challenges.database.object.ChallengeLevel)}.
|
||||||
|
* @throws InterruptedException
|
||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testDeleteChallengeLevel() {
|
public void testDeleteChallengeLevel() throws InterruptedException {
|
||||||
fail("Not yet implemented");
|
this.testAddChallengeToLevel();
|
||||||
|
assertTrue(cm.containsLevel(levelName));
|
||||||
|
cm.deleteChallengeLevel(level);
|
||||||
|
assertFalse(cm.containsLevel(levelName));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Test method for {@link world.bentobox.challenges.ChallengesManager#hasAnyChallengeData(org.bukkit.World)}.
|
* Test method for {@link world.bentobox.challenges.ChallengesManager#hasAnyChallengeData(org.bukkit.World)}.
|
||||||
|
* @throws InterruptedException
|
||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testHasAnyChallengeDataWorld() {
|
public void testHasAnyChallengeDataWorld() throws InterruptedException {
|
||||||
fail("Not yet implemented");
|
assertFalse(cm.hasAnyChallengeData(world));
|
||||||
|
this.testLoad();
|
||||||
|
assertTrue(cm.hasAnyChallengeData(world));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Test method for {@link world.bentobox.challenges.ChallengesManager#hasAnyChallengeData(java.lang.String)}.
|
* Test method for {@link world.bentobox.challenges.ChallengesManager#hasAnyChallengeData(java.lang.String)}.
|
||||||
|
* @throws InterruptedException
|
||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testHasAnyChallengeDataString() {
|
public void testHasAnyChallengeDataString() throws InterruptedException {
|
||||||
fail("Not yet implemented");
|
assertFalse(cm.hasAnyChallengeData("BSkyBlock"));
|
||||||
|
this.testLoad();
|
||||||
|
assertTrue(cm.hasAnyChallengeData("BSkyBlock"));
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user