#450 Make reload & messages functionality use NewSetting

- Change ReloadCommand to use the new setting functionality
- Check and construct the messages file in NewSetting
- Unrelated: change MessagesManager not to extend CustomConfiguration anymore
This commit is contained in:
ljacqu 2016-01-31 09:55:02 +01:00
parent 059175f14e
commit e747dfeb7f
11 changed files with 185 additions and 123 deletions

View File

@ -34,7 +34,6 @@ import fr.xephi.authme.listener.AuthMePlayerListener18;
import fr.xephi.authme.listener.AuthMeServerListener; import fr.xephi.authme.listener.AuthMeServerListener;
import fr.xephi.authme.listener.AuthMeTabCompletePacketAdapter; import fr.xephi.authme.listener.AuthMeTabCompletePacketAdapter;
import fr.xephi.authme.mail.SendMailSSL; import fr.xephi.authme.mail.SendMailSSL;
import fr.xephi.authme.modules.ModuleManager;
import fr.xephi.authme.output.ConsoleFilter; import fr.xephi.authme.output.ConsoleFilter;
import fr.xephi.authme.output.Log4JFilter; import fr.xephi.authme.output.Log4JFilter;
import fr.xephi.authme.output.MessageKey; import fr.xephi.authme.output.MessageKey;
@ -110,7 +109,6 @@ public class AuthMe extends JavaPlugin {
private NewSetting newSettings; private NewSetting newSettings;
private Messages messages; private Messages messages;
private JsonCache playerBackup; private JsonCache playerBackup;
private ModuleManager moduleManager;
private PasswordSecurity passwordSecurity; private PasswordSecurity passwordSecurity;
private DataSource database; private DataSource database;
@ -219,15 +217,14 @@ public class AuthMe extends JavaPlugin {
setPluginInfos(); setPluginInfos();
// Load settings and custom configurations, if it fails, stop the server due to security reasons. // Load settings and custom configurations, if it fails, stop the server due to security reasons.
newSettings = createNewSetting();
if (loadSettings()) { if (loadSettings()) {
server.shutdown(); server.shutdown();
setEnabled(false); setEnabled(false);
return; return;
} }
newSettings = createNewSetting();
// Set up messages & password security messages = new Messages(Settings.messageFile);
messages = Messages.getInstance();
// Connect to the database and setup tables // Connect to the database and setup tables
try { try {
@ -247,9 +244,6 @@ public class AuthMe extends JavaPlugin {
permsMan = initializePermissionsManager(); permsMan = initializePermissionsManager();
commandHandler = initializeCommandHandler(permsMan, messages, passwordSecurity, newSettings); commandHandler = initializeCommandHandler(permsMan, messages, passwordSecurity, newSettings);
// Set up the module manager
setupModuleManager();
// Setup otherAccounts file // Setup otherAccounts file
this.otherAccounts = OtherAccounts.getInstance(); this.otherAccounts = OtherAccounts.getInstance();
@ -327,21 +321,6 @@ public class AuthMe extends JavaPlugin {
ConsoleLogger.info("AuthMe " + this.getDescription().getVersion() + " correctly enabled!"); ConsoleLogger.info("AuthMe " + this.getDescription().getVersion() + " correctly enabled!");
} }
/**
* Set up the module manager.
*/
private void setupModuleManager() {
// TODO: Clean this up!
// TODO: split the plugin in more modules
// TODO: log number of loaded modules
// Define the module manager instance
moduleManager = new ModuleManager(this);
// Load the modules
// int loaded = moduleManager.loadModules();
}
/** /**
* Set up the mail API, if enabled. * Set up the mail API, if enabled.
*/ */
@ -469,7 +448,7 @@ public class AuthMe extends JavaPlugin {
private NewSetting createNewSetting() { private NewSetting createNewSetting() {
File configFile = new File(getDataFolder() + "config.yml"); File configFile = new File(getDataFolder() + "config.yml");
return new NewSetting(getConfig(), configFile); return new NewSetting(getConfig(), configFile, getDataFolder());
} }
/** /**
@ -536,18 +515,15 @@ public class AuthMe extends JavaPlugin {
} }
// Do backup on stop if enabled // Do backup on stop if enabled
if (newSettings != null) {
new PerformBackup(plugin, newSettings).doBackup(PerformBackup.BackupCause.STOP); new PerformBackup(plugin, newSettings).doBackup(PerformBackup.BackupCause.STOP);
// Unload modules
if (moduleManager != null) {
moduleManager.unloadModules();
} }
List<BukkitTask> pendingTasks = getServer().getScheduler().getPendingTasks(); List<BukkitTask> pendingTasks = getServer().getScheduler().getPendingTasks();
for (Iterator<BukkitTask> iterator = pendingTasks.iterator(); iterator.hasNext();) { for (Iterator<BukkitTask> iterator = pendingTasks.iterator(); iterator.hasNext();) {
BukkitTask pendingTask = iterator.next(); BukkitTask pendingTask = iterator.next();
if (!pendingTask.getOwner().equals(this) || pendingTask.isSync()) { if (!pendingTask.getOwner().equals(this) || pendingTask.isSync()) {
//remove all unrelevant tasks //remove all irrelevant tasks
iterator.remove(); iterator.remove();
} }
} }
@ -973,10 +949,6 @@ public class AuthMe extends JavaPlugin {
return count >= Settings.getMaxJoinPerIp; return count >= Settings.getMaxJoinPerIp;
} }
public ModuleManager getModuleManager() {
return moduleManager;
}
/** /**
* Handle Bukkit commands. * Handle Bukkit commands.
* *

View File

@ -12,6 +12,7 @@ import fr.xephi.authme.settings.NewSetting;
import fr.xephi.authme.settings.domain.Property; import fr.xephi.authme.settings.domain.Property;
import org.bukkit.command.CommandSender; import org.bukkit.command.CommandSender;
import java.io.File;
import java.util.List; import java.util.List;
/** /**
@ -101,6 +102,16 @@ public class CommandService {
return authMe.getDataSource(); return authMe.getDataSource();
} }
/**
* Return the AuthMe instance for further manipulation. Use only if other methods from
* the command service cannot be used.
*
* @return The AuthMe instance
*/
public AuthMe getAuthMe() {
return authMe;
}
/** /**
* Return the PasswordSecurity instance. * Return the PasswordSecurity instance.
* *
@ -152,6 +163,15 @@ public class CommandService {
return messages.retrieve(key); return messages.retrieve(key);
} }
/**
* Change the messages instance to retrieve messages from the given file.
*
* @param file The new file to read messages from
*/
public void reloadMessages(File file) {
messages.reload(file);
}
/** /**
* Retrieve the given property's value. * Retrieve the given property's value.
* *
@ -163,4 +183,13 @@ public class CommandService {
return settings.getProperty(property); return settings.getProperty(property);
} }
/**
* Return the settings manager.
*
* @return The settings manager
*/
public NewSetting getSettings() {
return settings;
}
} }

View File

@ -1,36 +1,32 @@
package fr.xephi.authme.command.executable.authme; package fr.xephi.authme.command.executable.authme;
import java.util.List;
import org.bukkit.command.CommandSender;
import fr.xephi.authme.AuthMe; import fr.xephi.authme.AuthMe;
import fr.xephi.authme.ConsoleLogger; import fr.xephi.authme.ConsoleLogger;
import fr.xephi.authme.command.CommandService; import fr.xephi.authme.command.CommandService;
import fr.xephi.authme.command.ExecutableCommand; import fr.xephi.authme.command.ExecutableCommand;
import fr.xephi.authme.output.MessageKey; import fr.xephi.authme.output.MessageKey;
import fr.xephi.authme.output.Messages; import org.bukkit.command.CommandSender;
import fr.xephi.authme.settings.Settings;
import java.util.List;
/**
* The reload command.
*/
public class ReloadCommand implements ExecutableCommand { public class ReloadCommand implements ExecutableCommand {
@Override @Override
public void executeCommand(CommandSender sender, List<String> arguments, CommandService commandService) { public void executeCommand(CommandSender sender, List<String> arguments, CommandService commandService) {
// AuthMe plugin instance AuthMe plugin = commandService.getAuthMe();
AuthMe plugin = AuthMe.getInstance();
try { try {
Settings.reload(); commandService.getSettings().reload();
Messages.getInstance().reloadManager(); commandService.reloadMessages(commandService.getSettings().getMessagesFile());
plugin.getModuleManager().reloadModules();
plugin.setupDatabase(); plugin.setupDatabase();
commandService.send(sender, MessageKey.CONFIG_RELOAD_SUCCESS);
} catch (Exception e) { } catch (Exception e) {
sender.sendMessage("Error occurred during reload of AuthMe: aborting"); sender.sendMessage("Error occurred during reload of AuthMe: aborting");
ConsoleLogger.showError("Fatal error occurred! AuthMe instance ABORTED!"); ConsoleLogger.showError("Fatal error occurred! AuthMe instance ABORTED!");
ConsoleLogger.writeStackTrace(e); ConsoleLogger.writeStackTrace(e);
plugin.stopOrUnload(); plugin.stopOrUnload();
} }
commandService.send(sender, MessageKey.CONFIG_RELOAD_SUCCESS);
} }
} }

View File

@ -1,9 +1,10 @@
package fr.xephi.authme.output; package fr.xephi.authme.output;
import fr.xephi.authme.settings.Settings;
import fr.xephi.authme.util.StringUtils; import fr.xephi.authme.util.StringUtils;
import org.bukkit.command.CommandSender; import org.bukkit.command.CommandSender;
import java.io.File;
/** /**
* Class for retrieving and sending translatable messages to players. * Class for retrieving and sending translatable messages to players.
* This class detects when the language settings have changed and will * This class detects when the language settings have changed and will
@ -11,27 +12,15 @@ import org.bukkit.command.CommandSender;
*/ */
public class Messages { public class Messages {
private static Messages singleton;
private final String language;
private MessagesManager manager; private MessagesManager manager;
private Messages(String language, MessagesManager manager) {
this.language = language;
this.manager = manager;
}
/** /**
* Get the instance of Messages. * Constructor.
* *
* @return The Messages instance * @param messageFile The messages file to use
*/ */
public static Messages getInstance() { public Messages(File messageFile) {
if (singleton == null) { manager = new MessagesManager(messageFile);
MessagesManager manager = new MessagesManager(Settings.messageFile);
singleton = new Messages(Settings.messagesLanguage, manager);
}
return singleton;
} }
/** /**
@ -60,7 +49,8 @@ public class Messages {
String message = retrieveSingle(key); String message = retrieveSingle(key);
String[] tags = key.getTags(); String[] tags = key.getTags();
if (replacements.length != tags.length) { if (replacements.length != tags.length) {
throw new RuntimeException("Given replacement size does not match the tags in message key '" + key + "'"); throw new IllegalStateException(
"Given replacement size does not match the tags in message key '" + key + "'");
} }
for (int i = 0; i < tags.length; ++i) { for (int i = 0; i < tags.length; ++i) {
@ -80,9 +70,6 @@ public class Messages {
* @return The message split by new lines * @return The message split by new lines
*/ */
public String[] retrieve(MessageKey key) { public String[] retrieve(MessageKey key) {
if (!Settings.messagesLanguage.equalsIgnoreCase(language)) {
reloadManager();
}
return manager.retrieve(key.getKey()); return manager.retrieve(key.getKey());
} }
@ -100,8 +87,8 @@ public class Messages {
/** /**
* Reload the messages manager. * Reload the messages manager.
*/ */
public void reloadManager() { public void reload(File messagesFile) {
manager = new MessagesManager(Settings.messageFile); manager = new MessagesManager(messagesFile);
} }
} }

View File

@ -1,8 +1,8 @@
package fr.xephi.authme.output; package fr.xephi.authme.output;
import fr.xephi.authme.ConsoleLogger; import fr.xephi.authme.ConsoleLogger;
import fr.xephi.authme.settings.CustomConfiguration;
import org.bukkit.ChatColor; import org.bukkit.ChatColor;
import org.bukkit.configuration.file.YamlConfiguration;
import java.io.File; import java.io.File;
@ -12,7 +12,10 @@ import java.io.File;
* This class is used within {@link Messages}, which offers a high-level interface for accessing * This class is used within {@link Messages}, which offers a high-level interface for accessing
* or sending messages from a properties file. * or sending messages from a properties file.
*/ */
class MessagesManager extends CustomConfiguration { class MessagesManager {
private final YamlConfiguration configuration;
private final String fileName;
/** /**
* Constructor for Messages. * Constructor for Messages.
@ -20,8 +23,8 @@ class MessagesManager extends CustomConfiguration {
* @param file the configuration file * @param file the configuration file
*/ */
MessagesManager(File file) { MessagesManager(File file) {
super(file); this.fileName = file.getName();
load(); this.configuration = YamlConfiguration.loadConfiguration(file);
} }
/** /**
@ -31,24 +34,22 @@ class MessagesManager extends CustomConfiguration {
* *
* @return The message * @return The message
*/ */
String[] retrieve(String key) { public String[] retrieve(String key) {
String message = (String) get(key); String message = configuration.getString(key);
if (message != null) { if (message != null) {
return formatMessage(message); return formatMessage(message);
} }
// Message is null: log key not being found and send error back as message // Message is null: log key not being found and send error back as message
String retrievalError = "Error getting message with key '" + key + "'. "; String retrievalError = "Error getting message with key '" + key + "'. ";
ConsoleLogger.showError(retrievalError + "Please verify your config file at '" ConsoleLogger.showError(retrievalError + "Please verify your config file at '" + fileName + "'");
+ getConfigFile().getName() + "'");
return new String[]{ return new String[]{
retrievalError + "Please contact the admin to verify or update the AuthMe messages file."}; retrievalError + "Please contact the admin to verify or update the AuthMe messages file."};
} }
static String[] formatMessage(String message) { private static String[] formatMessage(String message) {
String[] lines = message.split("&n"); String[] lines = message.split("&n");
for (int i = 0; i < lines.length; ++i) { for (int i = 0; i < lines.length; ++i) {
// We don't initialize a StringBuilder here because mostly we will only have one entry
lines[i] = ChatColor.translateAlternateColorCodes('&', lines[i]); lines[i] = ChatColor.translateAlternateColorCodes('&', lines[i]);
} }
return lines; return lines;

View File

@ -3,11 +3,13 @@ package fr.xephi.authme.settings;
import com.google.common.annotations.VisibleForTesting; import com.google.common.annotations.VisibleForTesting;
import fr.xephi.authme.ConsoleLogger; import fr.xephi.authme.ConsoleLogger;
import fr.xephi.authme.settings.domain.Property; import fr.xephi.authme.settings.domain.Property;
import fr.xephi.authme.settings.properties.PluginSettings;
import fr.xephi.authme.settings.properties.SettingsFieldRetriever; import fr.xephi.authme.settings.properties.SettingsFieldRetriever;
import fr.xephi.authme.settings.propertymap.PropertyMap; import fr.xephi.authme.settings.propertymap.PropertyMap;
import fr.xephi.authme.util.CollectionUtils; import fr.xephi.authme.util.CollectionUtils;
import fr.xephi.authme.util.StringUtils; import fr.xephi.authme.util.StringUtils;
import org.bukkit.configuration.file.FileConfiguration; import org.bukkit.configuration.file.FileConfiguration;
import org.bukkit.configuration.file.YamlConfiguration;
import org.yaml.snakeyaml.DumperOptions; import org.yaml.snakeyaml.DumperOptions;
import org.yaml.snakeyaml.Yaml; import org.yaml.snakeyaml.Yaml;
@ -19,23 +21,30 @@ import java.util.Arrays;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import static fr.xephi.authme.util.StringUtils.makePath;
/** /**
* The new settings manager. * The new settings manager.
*/ */
public class NewSetting { public class NewSetting {
private File file; private final File pluginFolder;
private final File configFile;
private FileConfiguration configuration; private FileConfiguration configuration;
private File messagesFile;
/** /**
* Constructor. Checks the given {@link FileConfiguration} object for completeness. * Constructor. Checks the given {@link FileConfiguration} object for completeness.
* *
* @param configuration The configuration to interact with * @param configuration The configuration to interact with
* @param file The configuration file * @param configFile The configuration file
* @param pluginFolder The AuthMe plugin folder
*/ */
public NewSetting(FileConfiguration configuration, File file) { public NewSetting(FileConfiguration configuration, File configFile, File pluginFolder) {
this.configuration = configuration; this.configuration = configuration;
this.file = file; this.configFile = configFile;
this.pluginFolder = pluginFolder;
messagesFile = buildMessagesFile();
PropertyMap propertyMap = SettingsFieldRetriever.getAllPropertyFields(); PropertyMap propertyMap = SettingsFieldRetriever.getAllPropertyFields();
if (SettingsMigrationService.checkAndMigrate(configuration, propertyMap)) { if (SettingsMigrationService.checkAndMigrate(configuration, propertyMap)) {
@ -49,13 +58,14 @@ public class NewSetting {
* Constructor for testing purposes, allowing more options. * Constructor for testing purposes, allowing more options.
* *
* @param configuration The FileConfiguration object to use * @param configuration The FileConfiguration object to use
* @param file The file to write to * @param configFile The file to write to
* @param propertyMap The property map whose properties should be verified for presence, or null to skip this * @param propertyMap The property map whose properties should be verified for presence, or null to skip this
*/ */
@VisibleForTesting @VisibleForTesting
NewSetting(FileConfiguration configuration, File file, PropertyMap propertyMap) { NewSetting(FileConfiguration configuration, File configFile, PropertyMap propertyMap) {
this.configuration = configuration; this.configuration = configuration;
this.file = file; this.configFile = configFile;
this.pluginFolder = new File("");
if (propertyMap != null && SettingsMigrationService.checkAndMigrate(configuration, propertyMap)) { if (propertyMap != null && SettingsMigrationService.checkAndMigrate(configuration, propertyMap)) {
save(propertyMap); save(propertyMap);
@ -91,8 +101,24 @@ public class NewSetting {
save(SettingsFieldRetriever.getAllPropertyFields()); save(SettingsFieldRetriever.getAllPropertyFields());
} }
/**
* Return the messages file based on the messages language config.
*
* @return The messages file to read messages from
*/
public File getMessagesFile() {
return messagesFile;
}
/**
* Reload the configuration.
*/
public void reload() {
configuration = YamlConfiguration.loadConfiguration(configFile);
}
private void save(PropertyMap propertyMap) { private void save(PropertyMap propertyMap) {
try (FileWriter writer = new FileWriter(file)) { try (FileWriter writer = new FileWriter(configFile)) {
Yaml simpleYaml = newYaml(false); Yaml simpleYaml = newYaml(false);
Yaml singleQuoteYaml = newYaml(true); Yaml singleQuoteYaml = newYaml(true);
@ -161,6 +187,20 @@ public class NewSetting {
return join("\n" + indent(indent), representation.split("\\n")); return join("\n" + indent(indent), representation.split("\\n"));
} }
private File buildMessagesFile() {
String languageCode = getProperty(PluginSettings.MESSAGES_LANGUAGE);
File messagesFile = buildMessagesFileFromCode(languageCode);
if (messagesFile.exists()) {
return messagesFile;
}
return buildMessagesFileFromCode("en");
}
private File buildMessagesFileFromCode(String language) {
return new File(pluginFolder.getName(),
makePath("messages", "messages_" + language + ".yml"));
}
private static Yaml newYaml(boolean useSingleQuotes) { private static Yaml newYaml(boolean useSingleQuotes) {
DumperOptions options = new DumperOptions(); DumperOptions options = new DumperOptions();
options.setDefaultFlowStyle(DumperOptions.FlowStyle.BLOCK); options.setDefaultFlowStyle(DumperOptions.FlowStyle.BLOCK);

View File

@ -4,6 +4,7 @@ import net.ricecode.similarity.LevenshteinDistanceStrategy;
import net.ricecode.similarity.StringSimilarityService; import net.ricecode.similarity.StringSimilarityService;
import net.ricecode.similarity.StringSimilarityServiceImpl; import net.ricecode.similarity.StringSimilarityServiceImpl;
import java.io.File;
import java.util.Arrays; import java.util.Arrays;
/** /**
@ -37,12 +38,12 @@ public final class StringUtils {
} }
/** /**
* Returns whether the given string contains any of the provided elements. * Return whether the given string contains any of the provided elements.
* *
* @param str the string to analyze * @param str The string to analyze
* @param pieces the items to check the string for * @param pieces The items to check the string for
* *
* @return true if the string contains at least one of the items * @return True if the string contains at least one of the items
*/ */
public static boolean containsAny(String str, String... pieces) { public static boolean containsAny(String str, String... pieces) {
if (str == null) { if (str == null) {
@ -60,21 +61,21 @@ public final class StringUtils {
* Null-safe method for checking whether a string is empty. Note that the string * Null-safe method for checking whether a string is empty. Note that the string
* is trimmed, so this method also considers a string with whitespace as empty. * is trimmed, so this method also considers a string with whitespace as empty.
* *
* @param str the string to verify * @param str The string to verify
* *
* @return true if the string is empty, false otherwise * @return True if the string is empty, false otherwise
*/ */
public static boolean isEmpty(String str) { public static boolean isEmpty(String str) {
return str == null || str.trim().isEmpty(); return str == null || str.trim().isEmpty();
} }
/** /**
* Joins a list of elements into a single string with the specified delimiter. * Join a list of elements into a single string with the specified delimiter.
* *
* @param delimiter the delimiter to use * @param delimiter The delimiter to use
* @param elements the elements to join * @param elements The elements to join
* *
* @return a new String that is composed of the elements separated by the delimiter * @return A new String that is composed of the elements separated by the delimiter
*/ */
public static String join(String delimiter, Iterable<String> elements) { public static String join(String delimiter, Iterable<String> elements) {
if (delimiter == null) { if (delimiter == null) {
@ -95,12 +96,12 @@ public final class StringUtils {
} }
/** /**
* Joins a list of elements into a single string with the specified delimiter. * Join a list of elements into a single string with the specified delimiter.
* *
* @param delimiter the delimiter to use * @param delimiter The delimiter to use
* @param elements the elements to join * @param elements The elements to join
* *
* @return a new String that is composed of the elements separated by the delimiter * @return A new String that is composed of the elements separated by the delimiter
*/ */
public static String join(String delimiter, String... elements) { public static String join(String delimiter, String... elements) {
return join(delimiter, Arrays.asList(elements)); return join(delimiter, Arrays.asList(elements));
@ -117,4 +118,15 @@ public final class StringUtils {
return "[" + th.getClass().getSimpleName() + "]: " + th.getMessage(); return "[" + th.getClass().getSimpleName() + "]: " + th.getMessage();
} }
/**
* Construct a file path from the given elements, i.e. separate the given elements by the file separator.
*
* @param elements The elements to create a path with
*
* @return The created path
*/
public static String makePath(String... elements) {
return join(File.separator, elements);
}
} }

View File

@ -18,6 +18,7 @@ import org.junit.Ignore;
import org.junit.Test; import org.junit.Test;
import org.mockito.ArgumentCaptor; import org.mockito.ArgumentCaptor;
import java.io.File;
import java.util.Arrays; import java.util.Arrays;
import java.util.List; import java.util.List;
@ -95,19 +96,6 @@ public class CommandServiceTest {
verify(commandMapper).mapPartsToCommand(sender, commandParts); verify(commandMapper).mapPartsToCommand(sender, commandParts);
} }
@Test
@Ignore
public void shouldRunTaskInAsync() {
// given
Runnable runnable = mock(Runnable.class);
// when
commandService.runTaskAsynchronously(runnable);
// then
// TODO ljacqu 20151226: AuthMe#getServer() is final, i.e. not mockable
}
@Test @Test
public void shouldGetDataSource() { public void shouldGetDataSource() {
// given // given
@ -193,10 +181,40 @@ public class CommandServiceTest {
given(settings.getProperty(property)).willReturn(7); given(settings.getProperty(property)).willReturn(7);
// when // when
int result = settings.getProperty(property); int result = commandService.getProperty(property);
// then // then
assertThat(result, equalTo(7)); assertThat(result, equalTo(7));
verify(settings).getProperty(property); verify(settings).getProperty(property);
} }
@Test
public void shouldReloadMessages() {
// given
File file = new File("some/bogus-file.test");
// when
commandService.reloadMessages(file);
// then
verify(messages).reload(file);
}
@Test
public void shouldReturnSettings() {
// given/when
NewSetting result = commandService.getSettings();
// then
assertThat(result, equalTo(settings));
}
@Test
public void shouldReturnAuthMe() {
// given/when
AuthMe result = commandService.getAuthMe();
// then
assertThat(result, equalTo(authMe));
}
} }

View File

@ -1,6 +1,5 @@
package fr.xephi.authme.output; package fr.xephi.authme.output;
import fr.xephi.authme.settings.Settings;
import fr.xephi.authme.util.WrapperMock; import fr.xephi.authme.util.WrapperMock;
import org.bukkit.command.CommandSender; import org.bukkit.command.CommandSender;
import org.bukkit.entity.Player; import org.bukkit.entity.Player;
@ -37,15 +36,12 @@ public class MessagesIntegrationTest {
public void setUpMessages() { public void setUpMessages() {
WrapperMock.createInstance(); WrapperMock.createInstance();
Settings.messagesLanguage = "en";
URL url = getClass().getClassLoader().getResource(YML_TEST_FILE); URL url = getClass().getClassLoader().getResource(YML_TEST_FILE);
if (url == null) { if (url == null) {
throw new RuntimeException("File '" + YML_TEST_FILE + "' could not be loaded"); throw new RuntimeException("File '" + YML_TEST_FILE + "' could not be loaded");
} }
Settings.messageFile = new File(url.getFile()); messages = new Messages(new File(url.getFile()));
Settings.messagesLanguage = "en";
messages = Messages.getInstance();
} }
@Test @Test

View File

@ -2,6 +2,7 @@ package fr.xephi.authme.settings;
import fr.xephi.authme.settings.domain.Property; import fr.xephi.authme.settings.domain.Property;
import fr.xephi.authme.settings.properties.TestConfiguration; import fr.xephi.authme.settings.properties.TestConfiguration;
import fr.xephi.authme.settings.propertymap.PropertyMap;
import org.bukkit.configuration.file.YamlConfiguration; import org.bukkit.configuration.file.YamlConfiguration;
import org.junit.Test; import org.junit.Test;
import org.mockito.invocation.InvocationOnMock; import org.mockito.invocation.InvocationOnMock;
@ -40,7 +41,7 @@ public class NewSettingTest {
setReturnValue(file, TestConfiguration.SYSTEM_NAME, "myTestSys"); setReturnValue(file, TestConfiguration.SYSTEM_NAME, "myTestSys");
// when / then // when / then
NewSetting settings = new NewSetting(file, new File("conf.txt"), null); NewSetting settings = new NewSetting(file, new File("conf.txt"), (PropertyMap) null);
assertThat(settings.getProperty(TestConfiguration.VERSION_NUMBER), equalTo(20)); assertThat(settings.getProperty(TestConfiguration.VERSION_NUMBER), equalTo(20));
assertThat(settings.getProperty(TestConfiguration.SKIP_BORING_FEATURES), equalTo(true)); assertThat(settings.getProperty(TestConfiguration.SKIP_BORING_FEATURES), equalTo(true));

View File

@ -2,6 +2,7 @@ package fr.xephi.authme.util;
import org.junit.Test; import org.junit.Test;
import java.io.File;
import java.net.MalformedURLException; import java.net.MalformedURLException;
import java.util.Arrays; import java.util.Arrays;
import java.util.List; import java.util.List;
@ -135,4 +136,13 @@ public class StringUtilsTest {
assertThat(StringUtils.getDifference("test", "bear"), equalTo(0.75)); assertThat(StringUtils.getDifference("test", "bear"), equalTo(0.75));
assertThat(StringUtils.getDifference("test", "something"), greaterThan(0.88)); assertThat(StringUtils.getDifference("test", "something"), greaterThan(0.88));
} }
@Test
public void shouldConstructPath() {
// given/when
String result = StringUtils.makePath("path", "to", "test-file.txt");
// then
assertThat(result, equalTo("path" + File.separator + "to" + File.separator + "test-file.txt"));
}
} }