mirror of
https://github.com/plan-player-analytics/Plan.git
synced 2025-01-15 04:31:34 +01:00
Merge pull request #244 from Fuzzlemann/master
PR for 3.6.3 (Fuzzlemann) (3)
This commit is contained in:
commit
45aaaaafeb
@ -3,9 +3,10 @@
|
||||
<modelVersion>4.0.0</modelVersion>
|
||||
<groupId>com.djrapitops</groupId>
|
||||
<artifactId>Plan</artifactId>
|
||||
<version>3.6.0</version>
|
||||
<version>3.6.3</version>
|
||||
<build>
|
||||
<sourceDirectory>${basedir}/src</sourceDirectory>
|
||||
<testSourceDirectory>${basedir}/test</testSourceDirectory>
|
||||
<defaultGoal>clean package install</defaultGoal>
|
||||
<resources>
|
||||
<resource>
|
||||
@ -16,6 +17,7 @@
|
||||
<include>*.js</include>
|
||||
<include>*.yml</include>
|
||||
<include>*.html</include>
|
||||
<include>*.txt</include>
|
||||
</includes>
|
||||
</resource>
|
||||
</resources>
|
||||
@ -70,18 +72,9 @@
|
||||
</configuration>
|
||||
</plugin>
|
||||
<plugin>
|
||||
<groupId>org.pitest</groupId>
|
||||
<artifactId>pitest-maven</artifactId>
|
||||
<version>1.1.8</version>
|
||||
<configuration>
|
||||
<targetClasses>
|
||||
<param>main.java.com.djrapitops.plan.*</param>
|
||||
</targetClasses>
|
||||
<targetTests>
|
||||
<param>test.java.main.java.com.djrapitops.plan.*</param>
|
||||
</targetTests>
|
||||
<timeoutConstant>1000</timeoutConstant>
|
||||
</configuration>
|
||||
<groupId>org.jacoco</groupId>
|
||||
<artifactId>jacoco-maven-plugin</artifactId>
|
||||
<version>0.7.9</version>
|
||||
</plugin>
|
||||
<plugin>
|
||||
<artifactId>maven-checkstyle-plugin</artifactId>
|
||||
@ -181,6 +174,9 @@
|
||||
</dependencies>
|
||||
<properties>
|
||||
<sonar.language>java</sonar.language>
|
||||
<sonar.jacoco.reportPath>${project.basedir}/target/jacoco.exec</sonar.jacoco.reportPath>
|
||||
<sonar.dynamicAnalysis>reuseReports</sonar.dynamicAnalysis>
|
||||
<sonar.java.coveragePlugin>jacoco</sonar.java.coveragePlugin>
|
||||
<maven.compiler.source>1.8</maven.compiler.source>
|
||||
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
|
||||
<maven.compiler.target>1.8</maven.compiler.target>
|
||||
|
19
Plan/pom.xml
19
Plan/pom.xml
@ -100,6 +100,7 @@
|
||||
<defaultGoal>clean package install</defaultGoal>
|
||||
<finalName>${project.name}</finalName>
|
||||
<sourceDirectory>${basedir}/src</sourceDirectory>
|
||||
<testSourceDirectory>${basedir}/test</testSourceDirectory>
|
||||
<resources>
|
||||
<resource>
|
||||
<targetPath>.</targetPath>
|
||||
@ -165,18 +166,9 @@
|
||||
</configuration>
|
||||
</plugin>
|
||||
<plugin>
|
||||
<groupId>org.pitest</groupId>
|
||||
<artifactId>pitest-maven</artifactId>
|
||||
<version>1.1.8</version>
|
||||
<configuration>
|
||||
<targetClasses>
|
||||
<param>main.java.com.djrapitops.plan.*</param>
|
||||
</targetClasses>
|
||||
<targetTests>
|
||||
<param>test.java.main.java.com.djrapitops.plan.*</param>
|
||||
</targetTests>
|
||||
<timeoutConstant>1000</timeoutConstant>
|
||||
</configuration>
|
||||
<groupId>org.jacoco</groupId>
|
||||
<artifactId>jacoco-maven-plugin</artifactId>
|
||||
<version>0.7.9</version>
|
||||
</plugin>
|
||||
<plugin>
|
||||
<groupId>org.apache.maven.plugins</groupId>
|
||||
@ -202,5 +194,8 @@
|
||||
<maven.compiler.source>1.8</maven.compiler.source>
|
||||
<maven.compiler.target>1.8</maven.compiler.target>
|
||||
<sonar.language>java</sonar.language>
|
||||
<sonar.java.coveragePlugin>jacoco</sonar.java.coveragePlugin>
|
||||
<sonar.dynamicAnalysis>reuseReports</sonar.dynamicAnalysis>
|
||||
<sonar.jacoco.reportPaths>${project.basedir}/target/jacoco.exec</sonar.jacoco.reportPaths>
|
||||
</properties>
|
||||
</project>
|
@ -212,8 +212,8 @@ public class UserData {
|
||||
if (addIps.isEmpty()) {
|
||||
return;
|
||||
}
|
||||
ips.addAll(addIps.stream().filter(Verify::notNull).collect(Collectors.toList()));
|
||||
|
||||
ips.addAll(addIps.stream().filter(Verify::notNull).collect(Collectors.toList()));
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -54,8 +54,8 @@ public class PluginConfigSectionHandler {
|
||||
String pluginName = dataSource.getSourcePlugin();
|
||||
if (!section.getBoolean(pluginName + ".Enabled")) {
|
||||
return false;
|
||||
|
||||
}
|
||||
|
||||
String source = dataSource.placeholder;
|
||||
return section.getBoolean(pluginName + ".Data." + source);
|
||||
}
|
||||
|
@ -60,7 +60,7 @@ public class AnalysisCacheHandler {
|
||||
* @return true if there is data in the cache.
|
||||
*/
|
||||
public boolean isCached() {
|
||||
return (cache != null);
|
||||
return cache != null;
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -9,7 +9,6 @@ import java.io.BufferedReader;
|
||||
import java.io.InputStreamReader;
|
||||
import java.net.MalformedURLException;
|
||||
import java.net.URL;
|
||||
import java.util.Map;
|
||||
|
||||
/**
|
||||
* This class contains the geolocation cache.
|
||||
@ -48,12 +47,10 @@ public class GeolocationCacheHandler {
|
||||
public static String getCountry(String ipAddress) {
|
||||
Log.debug("Started country retrieval from IP Address " + ipAddress);
|
||||
|
||||
Map<String, String> geolocationMap = geolocationCache.asMap();
|
||||
String country = geolocationMap.get(ipAddress);
|
||||
|
||||
Log.debug("Got country from " + ipAddress + " out of cache: " + country + " (if null, country wasn't cached)");
|
||||
String country = getCachedCountry(ipAddress);
|
||||
|
||||
if (country != null) {
|
||||
Log.debug("Got cached country from IP Address " + ipAddress + ": " + country);
|
||||
return country;
|
||||
} else {
|
||||
country = getUncachedCountry(ipAddress);
|
||||
@ -77,7 +74,7 @@ public class GeolocationCacheHandler {
|
||||
* @see <a href="http://freegeoip.net">http://freegeoip.net</a>
|
||||
* @see #getCountry(String)
|
||||
*/
|
||||
private static String getUncachedCountry(String ipAddress) {
|
||||
public static String getUncachedCountry(String ipAddress) {
|
||||
Benchmark.start("getUncachedCountry");
|
||||
|
||||
URL url;
|
||||
@ -104,4 +101,24 @@ public class GeolocationCacheHandler {
|
||||
Benchmark.stop("getUncachedCountry");
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the cached country
|
||||
*
|
||||
* @param ipAddress The IP Address which is retrieved out of the cache
|
||||
* @return The cached country, {@code null} if the country is not cached
|
||||
*/
|
||||
public static String getCachedCountry(String ipAddress) {
|
||||
return geolocationCache.getIfPresent(ipAddress);
|
||||
}
|
||||
|
||||
/**
|
||||
* Checks if the IP Address is cached
|
||||
*
|
||||
* @param ipAddress The IP Address which is checked
|
||||
* @return true if the IP Address is cached
|
||||
*/
|
||||
public static boolean isCached(String ipAddress) {
|
||||
return geolocationCache.asMap().containsKey(ipAddress);
|
||||
}
|
||||
}
|
||||
|
@ -4,6 +4,9 @@ import com.google.common.cache.Cache;
|
||||
import com.google.common.cache.CacheBuilder;
|
||||
import main.java.com.djrapitops.plan.ui.webserver.response.Response;
|
||||
|
||||
import java.util.Map;
|
||||
import java.util.function.Predicate;
|
||||
|
||||
/**
|
||||
* This class contains the page cache.
|
||||
* <p>
|
||||
@ -67,10 +70,35 @@ public class PageCacheHandler {
|
||||
pageCache.put(identifier, response);
|
||||
}
|
||||
|
||||
/**
|
||||
* Checks if the page is cached.
|
||||
*
|
||||
* @param identifier The identifier of the page
|
||||
* @return true if the page is cached
|
||||
*/
|
||||
public static boolean isCached(String identifier) {
|
||||
return pageCache.asMap().containsKey(identifier);
|
||||
}
|
||||
|
||||
/**
|
||||
* Removes all of the elements of this cache that satisfy the given predicate.
|
||||
*
|
||||
* @param filter a predicate which returns true for entries to be removed
|
||||
*/
|
||||
public static void removeIf(Predicate<String> filter) {
|
||||
Map<String, Response> pageCacheMap = pageCache.asMap();
|
||||
|
||||
for (String identifier : pageCacheMap.keySet()) {
|
||||
if (filter.test(identifier)) {
|
||||
pageCache.invalidate(identifier);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Clears the cache from all its contents.
|
||||
*/
|
||||
public static void clearCache() {
|
||||
pageCache.asMap().clear();
|
||||
pageCache.invalidateAll();
|
||||
}
|
||||
}
|
||||
|
@ -50,8 +50,7 @@ public class DataCacheGetQueue extends Queue<Map<UUID, List<DBCallableProcessor>
|
||||
}
|
||||
|
||||
boolean containsUUIDtoBeCached(UUID uuid) {
|
||||
return uuid != null
|
||||
&& queue.stream()
|
||||
return uuid != null && queue.stream()
|
||||
.map(map -> map.get(uuid))
|
||||
.filter(Objects::nonNull)
|
||||
.anyMatch(list -> list.size() >= 2);
|
||||
|
@ -4,6 +4,8 @@ import main.java.com.djrapitops.plan.Log;
|
||||
import main.java.com.djrapitops.plan.Plan;
|
||||
import main.java.com.djrapitops.plan.data.KillData;
|
||||
import main.java.com.djrapitops.plan.data.UserData;
|
||||
import org.apache.commons.lang3.text.WordUtils;
|
||||
import org.bukkit.Material;
|
||||
import org.bukkit.entity.LivingEntity;
|
||||
import org.bukkit.entity.Player;
|
||||
|
||||
@ -54,4 +56,14 @@ public class KillHandling {
|
||||
data.setMobKills(data.getMobKills() + 1);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Normalizes a material name
|
||||
*
|
||||
* @param material The material
|
||||
* @return The normalized material name
|
||||
*/
|
||||
public static String normalizeMaterialName(Material material) {
|
||||
return WordUtils.capitalizeFully(material.name(), '_').replace('_', ' ');
|
||||
}
|
||||
}
|
||||
|
@ -2,6 +2,7 @@ package main.java.com.djrapitops.plan.data.listeners;
|
||||
|
||||
import main.java.com.djrapitops.plan.Plan;
|
||||
import main.java.com.djrapitops.plan.data.cache.DataCacheHandler;
|
||||
import main.java.com.djrapitops.plan.data.handling.KillHandling;
|
||||
import main.java.com.djrapitops.plan.data.handling.info.DeathInfo;
|
||||
import main.java.com.djrapitops.plan.data.handling.info.KillInfo;
|
||||
import main.java.com.djrapitops.plan.utilities.MiscUtils;
|
||||
@ -68,7 +69,7 @@ public class PlanDeathEventListener implements Listener {
|
||||
}
|
||||
}
|
||||
|
||||
handler.addToPool(new KillInfo(killer.getUniqueId(), time, dead, itemInHand.name()));
|
||||
handler.addToPool(new KillInfo(killer.getUniqueId(), time, dead, KillHandling.normalizeMaterialName(itemInHand)));
|
||||
return;
|
||||
}
|
||||
|
||||
|
@ -29,7 +29,6 @@ public class PlanGamemodeChangeListener implements Listener {
|
||||
*/
|
||||
public PlanGamemodeChangeListener(Plan plugin) {
|
||||
handler = plugin.getHandler();
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -1,152 +0,0 @@
|
||||
package main.java.com.djrapitops.plan.ui.webserver;
|
||||
|
||||
import main.java.com.djrapitops.plan.Log;
|
||||
|
||||
import java.io.*;
|
||||
import java.util.Arrays;
|
||||
import java.util.Optional;
|
||||
|
||||
/**
|
||||
* Represents a HTTP Request.
|
||||
* <p>
|
||||
* Request is read from the given InputStream.
|
||||
* <p>
|
||||
* Closing the Request closes the InputStream. (Closing Socket InputStream
|
||||
* closes the socket.)
|
||||
* <p>
|
||||
* Request Strings should not be logged because they may contain base64 encoded
|
||||
* user:password Authorization combinations.
|
||||
*
|
||||
* @author Rsl1122
|
||||
* @since 3.5.2
|
||||
*/
|
||||
public class Request implements Closeable {
|
||||
|
||||
private final InputStream input;
|
||||
private String request;
|
||||
private String target;
|
||||
private String authorization;
|
||||
|
||||
private Closeable close;
|
||||
|
||||
/**
|
||||
* Creates a new Request object.
|
||||
*
|
||||
* @param input InputStream to read the socket.
|
||||
*/
|
||||
public Request(InputStream input) {
|
||||
this.input = input;
|
||||
}
|
||||
|
||||
/**
|
||||
* Reads the information in the Request and parses required information.
|
||||
* <p>
|
||||
* Parses Request (GET, POST etc.)
|
||||
* <p>
|
||||
* Parses Target (/home/etc)
|
||||
* <p>
|
||||
* Parses Authorization (Authorization header).
|
||||
*
|
||||
* @throws java.io.IOException if InputStream can not be read.
|
||||
*/
|
||||
public void parse() throws IOException {
|
||||
StringBuilder headerB = new StringBuilder();
|
||||
BufferedReader in = new BufferedReader(new InputStreamReader(input));
|
||||
close = in;
|
||||
while (true) {
|
||||
String line = in.readLine();
|
||||
if (line == null || line.isEmpty()) {
|
||||
break;
|
||||
}
|
||||
headerB.append(line);
|
||||
headerB.append(":::");
|
||||
}
|
||||
final String requestHeader = headerB.toString();
|
||||
String[] header = requestHeader.split(":::");
|
||||
parseRequestAndTarget(header);
|
||||
parseAuthorization(header);
|
||||
}
|
||||
|
||||
/**
|
||||
* Check if the request has Authorization: Basic header.
|
||||
*
|
||||
* @return true/false
|
||||
*/
|
||||
public boolean hasAuthorization() {
|
||||
return authorization != null;
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the base64 encoded Authorization if present.
|
||||
*
|
||||
* @return base64 encoded user:password or null.
|
||||
*/
|
||||
public String getAuthorization() {
|
||||
return authorization;
|
||||
}
|
||||
|
||||
private void parseAuthorization(String[] header) {
|
||||
Optional<String> auth = Arrays.stream(header)
|
||||
.filter(l -> l.contains("Authorization: Basic "))
|
||||
.findFirst();
|
||||
if (auth.isPresent()) {
|
||||
Log.debug("Found Authorization.");
|
||||
authorization = auth.get().replace("Authorization: Basic ", "");
|
||||
} else {
|
||||
Log.debug("Not Authorized.");
|
||||
}
|
||||
}
|
||||
|
||||
private void parseRequestAndTarget(String[] header) {
|
||||
String req = header[0];
|
||||
String[] reqLine = req.split(" ");
|
||||
if (reqLine.length >= 2) {
|
||||
request = reqLine[0];
|
||||
target = reqLine[1].replace("%20", " ")
|
||||
.replace("%2E", ".");
|
||||
;
|
||||
} else {
|
||||
request = "GET";
|
||||
target = "/";
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Used to get the request type.
|
||||
*
|
||||
* @return GET, POST, etc.
|
||||
*/
|
||||
public String getRequest() {
|
||||
return request;
|
||||
}
|
||||
|
||||
/**
|
||||
* Used to get the target.
|
||||
*
|
||||
* @return for example '/home/etc'
|
||||
*/
|
||||
public String getTarget() {
|
||||
return target;
|
||||
}
|
||||
|
||||
/**
|
||||
* Closes the Request.
|
||||
* <p>
|
||||
* Closes the InputStream.
|
||||
*
|
||||
* @throws IOException if the stream can not be closed.
|
||||
*/
|
||||
@Override
|
||||
public void close() throws IOException {
|
||||
close.close();
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return "Request{" +
|
||||
"request='" + request + '\'' +
|
||||
", target='" + target + '\'' +
|
||||
", authorization='" + authorization + '\'' +
|
||||
'}';
|
||||
}
|
||||
}
|
@ -38,4 +38,22 @@ public abstract class Response {
|
||||
public int getCode() {
|
||||
return header == null ? 500 : Integer.parseInt(header.split(" ")[1]);
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean equals(Object o) {
|
||||
if (this == o) return true;
|
||||
if (o == null || getClass() != o.getClass()) return false;
|
||||
|
||||
Response response = (Response) o;
|
||||
|
||||
return (header != null ? header.equals(response.header) : response.header == null)
|
||||
&& (content != null ? content.equals(response.content) : response.content == null);
|
||||
}
|
||||
|
||||
@Override
|
||||
public int hashCode() {
|
||||
int result = header != null ? header.hashCode() : 0;
|
||||
result = 31 * result + (content != null ? content.hashCode() : 0);
|
||||
return result;
|
||||
}
|
||||
}
|
||||
|
@ -165,8 +165,10 @@ public class Analysis {
|
||||
Log.info(Locale.get(Msg.ANALYSIS_FINISHED).parse(String.valueOf(time), HtmlUtils.getServerAnalysisUrlWithProtocol()));
|
||||
}
|
||||
|
||||
PageCacheHandler.removeIf(identifier -> identifier.startsWith("inspectPage: "));
|
||||
PageCacheHandler.cachePage("analysisPage", () -> new AnalysisPageResponse(plugin.getUiServer().getDataReqHandler()));
|
||||
PageCacheHandler.cachePage("players", () -> new PlayersPageResponse(plugin));
|
||||
|
||||
ExportUtility.export(analysisData, rawData);
|
||||
} catch (Exception e) {
|
||||
Log.toLog(this.getClass().getName(), e);
|
||||
|
@ -90,12 +90,7 @@ public class DumpLog {
|
||||
* @param line The content of the line
|
||||
*/
|
||||
private void addLine(CharSequence line) {
|
||||
if (line == null) {
|
||||
lines.add("\n");
|
||||
return;
|
||||
}
|
||||
|
||||
lines.add(line.toString());
|
||||
lines.add(line == null ? "\n" : line.toString());
|
||||
}
|
||||
|
||||
/**
|
||||
@ -138,16 +133,13 @@ public class DumpLog {
|
||||
connection.setDoOutput(true);
|
||||
|
||||
DataOutputStream wr = new DataOutputStream(connection.getOutputStream());
|
||||
wr.writeBytes(content);
|
||||
wr.writeBytes(this.toString());
|
||||
wr.flush();
|
||||
wr.close();
|
||||
|
||||
BufferedReader reader = new BufferedReader(new InputStreamReader(connection.getInputStream()));
|
||||
|
||||
String response = reader.readLine();
|
||||
|
||||
JSONParser parser = new JSONParser();
|
||||
JSONObject json = (JSONObject) parser.parse(response);
|
||||
JSONObject json = (JSONObject) parser.parse(reader.readLine());
|
||||
|
||||
return "https://hastebin.com/" + json.get("key");
|
||||
} catch (IOException | ParseException e) {
|
||||
|
@ -10,8 +10,8 @@ import org.junit.Test;
|
||||
import org.junit.runner.RunWith;
|
||||
import org.powermock.core.classloader.annotations.PrepareForTest;
|
||||
import org.powermock.modules.junit4.PowerMockRunner;
|
||||
import test.java.utils.MockUtils;
|
||||
import test.java.utils.TestInit;
|
||||
import test.java.utils.MockUtils;
|
||||
|
||||
import java.io.IOException;
|
||||
import java.net.InetAddress;
|
76
Plan/test/test/java/main/java/com/djrapitops/plan/data/cache/GeolocationCacheTest.java
vendored
Normal file
76
Plan/test/test/java/main/java/com/djrapitops/plan/data/cache/GeolocationCacheTest.java
vendored
Normal file
@ -0,0 +1,76 @@
|
||||
package test.java.main.java.com.djrapitops.plan.data.cache;
|
||||
|
||||
import main.java.com.djrapitops.plan.data.cache.GeolocationCacheHandler;
|
||||
import org.bukkit.plugin.java.JavaPlugin;
|
||||
import org.junit.Before;
|
||||
import org.junit.Test;
|
||||
import org.junit.runner.RunWith;
|
||||
import org.powermock.core.classloader.annotations.PrepareForTest;
|
||||
import org.powermock.modules.junit4.PowerMockRunner;
|
||||
import test.java.utils.TestInit;
|
||||
|
||||
import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
|
||||
import static junit.framework.TestCase.assertEquals;
|
||||
import static junit.framework.TestCase.assertFalse;
|
||||
import static junit.framework.TestCase.assertTrue;
|
||||
|
||||
/**
|
||||
* @author Fuzzlemann
|
||||
*/
|
||||
@RunWith(PowerMockRunner.class)
|
||||
@PrepareForTest(JavaPlugin.class)
|
||||
public class GeolocationCacheTest {
|
||||
|
||||
private Map<String, String> ipsToCountries = new HashMap<>();
|
||||
|
||||
@Before
|
||||
public void setUp() {
|
||||
ipsToCountries.put("8.8.8.8", "United States");
|
||||
ipsToCountries.put("8.8.4.4", "United States");
|
||||
ipsToCountries.put("4.4.2.2", "United States");
|
||||
ipsToCountries.put("208.67.222.222", "United States");
|
||||
ipsToCountries.put("208.67.220.220", "United States");
|
||||
ipsToCountries.put("205.210.42.205", "Canada");
|
||||
ipsToCountries.put("64.68.200.200", "Canada");
|
||||
ipsToCountries.put("0.0.0.0", "Not Known");
|
||||
ipsToCountries.put("127.0.0.1", "Not Known");
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testCountryGetting() throws Exception {
|
||||
TestInit.init();
|
||||
|
||||
for (Map.Entry<String, String> entry : ipsToCountries.entrySet()) {
|
||||
String ip = entry.getKey();
|
||||
String expCountry = entry.getValue();
|
||||
|
||||
String country = GeolocationCacheHandler.getUncachedCountry(ip);
|
||||
|
||||
assertEquals(country, expCountry);
|
||||
}
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testCaching() throws Exception {
|
||||
TestInit.init();
|
||||
|
||||
for (Map.Entry<String, String> entry : ipsToCountries.entrySet()) {
|
||||
String ip = entry.getKey();
|
||||
String expIp = entry.getValue();
|
||||
|
||||
String countryFirstCall = GeolocationCacheHandler.getUncachedCountry(ip);
|
||||
assertFalse(GeolocationCacheHandler.isCached(ip));
|
||||
|
||||
String countrySecondCall = GeolocationCacheHandler.getCountry(ip);
|
||||
assertTrue(GeolocationCacheHandler.isCached(ip));
|
||||
|
||||
String countryThirdCall = GeolocationCacheHandler.getCachedCountry(ip);
|
||||
|
||||
assertEquals(countryFirstCall, countrySecondCall);
|
||||
assertEquals(countrySecondCall, countryThirdCall);
|
||||
assertEquals(countryThirdCall, expIp);
|
||||
}
|
||||
}
|
||||
}
|
62
Plan/test/test/java/main/java/com/djrapitops/plan/data/cache/PageCacheHandlerTest.java
vendored
Normal file
62
Plan/test/test/java/main/java/com/djrapitops/plan/data/cache/PageCacheHandlerTest.java
vendored
Normal file
@ -0,0 +1,62 @@
|
||||
package test.java.main.java.com.djrapitops.plan.data.cache;
|
||||
|
||||
import main.java.com.djrapitops.plan.data.cache.PageCacheHandler;
|
||||
import main.java.com.djrapitops.plan.data.cache.PageLoader;
|
||||
import main.java.com.djrapitops.plan.ui.webserver.response.Response;
|
||||
import org.junit.Test;
|
||||
import test.java.utils.RandomData;
|
||||
|
||||
import static junit.framework.TestCase.*;
|
||||
|
||||
/**
|
||||
* @author Fuzzlemann
|
||||
*/
|
||||
public class PageCacheHandlerTest {
|
||||
private final String IDENTIFIER = RandomData.randomString(10);
|
||||
private final String RESPONSE_STRING = RandomData.randomString(10);
|
||||
private final Response RESPONSE = new Response() {
|
||||
@Override
|
||||
public String getResponse() {
|
||||
return RESPONSE_STRING;
|
||||
}
|
||||
};
|
||||
private final PageLoader LOADER = () -> RESPONSE;
|
||||
|
||||
@Test
|
||||
public void testCreateResponse() {
|
||||
String expResponse = RESPONSE.getResponse();
|
||||
String response = LOADER.createResponse().getResponse();
|
||||
|
||||
assertEquals(expResponse, response);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testCache() {
|
||||
Response expResponse = LOADER.createResponse();
|
||||
|
||||
assertFalse(PageCacheHandler.isCached(IDENTIFIER));
|
||||
|
||||
Response response = PageCacheHandler.loadPage(IDENTIFIER, LOADER);
|
||||
assertTrue(PageCacheHandler.isCached(IDENTIFIER));
|
||||
|
||||
assertEquals(expResponse, response);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testClearCache() {
|
||||
PageCacheHandler.cachePage(IDENTIFIER, LOADER);
|
||||
assertTrue(PageCacheHandler.isCached(IDENTIFIER));
|
||||
|
||||
PageCacheHandler.clearCache();
|
||||
assertFalse(PageCacheHandler.isCached(IDENTIFIER));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testRemoveIf() {
|
||||
PageCacheHandler.cachePage(IDENTIFIER, LOADER);
|
||||
assertTrue(PageCacheHandler.isCached(IDENTIFIER));
|
||||
|
||||
PageCacheHandler.removeIf(identifier -> identifier.equals(IDENTIFIER));
|
||||
assertFalse(PageCacheHandler.isCached(IDENTIFIER));
|
||||
}
|
||||
}
|
@ -36,18 +36,12 @@ public class SessionCacheTest {
|
||||
public SessionCacheTest() {
|
||||
}
|
||||
|
||||
/**
|
||||
*
|
||||
*/
|
||||
@Before
|
||||
public void setUp() throws Exception {
|
||||
TestInit.init();
|
||||
test = new SessionCache();
|
||||
}
|
||||
|
||||
/**
|
||||
*
|
||||
*/
|
||||
@Test
|
||||
public void testStartSession() {
|
||||
UUID uuid = MockUtils.getPlayerUUID();
|
||||
@ -55,9 +49,6 @@ public class SessionCacheTest {
|
||||
assertTrue("Didn't contain new session", test.getActiveSessions().containsKey(uuid));
|
||||
}
|
||||
|
||||
/**
|
||||
*
|
||||
*/
|
||||
@Test
|
||||
public void testEndSession() {
|
||||
UUID uuid = MockUtils.getPlayerUUID();
|
||||
@ -69,9 +60,6 @@ public class SessionCacheTest {
|
||||
assertTrue("Session not valid", testSession.isValid());
|
||||
}
|
||||
|
||||
/**
|
||||
*
|
||||
*/
|
||||
@Test
|
||||
public void testAddSession() {
|
||||
UUID uuid = MockUtils.getPlayerUUID();
|
@ -14,6 +14,7 @@ import main.java.com.djrapitops.plan.database.Database;
|
||||
import main.java.com.djrapitops.plan.database.databases.SQLiteDB;
|
||||
import main.java.com.djrapitops.plan.database.tables.UsersTable;
|
||||
import main.java.com.djrapitops.plan.utilities.MiscUtils;
|
||||
import org.bukkit.Material;
|
||||
import org.bukkit.entity.Player;
|
||||
import org.bukkit.plugin.java.JavaPlugin;
|
||||
import org.junit.After;
|
||||
@ -132,4 +133,13 @@ public class KillHandlingTest {
|
||||
assertEquals(exp, result);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testNormalizeMaterialName() {
|
||||
Material material = Material.GOLD_SWORD;
|
||||
String name = material.name();
|
||||
String normalizedName = KillHandling.normalizeMaterialName(material);
|
||||
|
||||
assertEquals(name, "GOLD_SWORD");
|
||||
assertEquals(normalizedName, "Gold Sword");
|
||||
}
|
||||
}
|
@ -20,8 +20,8 @@ import org.junit.Test;
|
||||
import org.junit.runner.RunWith;
|
||||
import org.powermock.core.classloader.annotations.PrepareForTest;
|
||||
import org.powermock.modules.junit4.PowerMockRunner;
|
||||
import test.java.utils.MockUtils;
|
||||
import test.java.utils.TestInit;
|
||||
import test.java.utils.MockUtils;
|
||||
|
||||
import java.sql.SQLException;
|
||||
import java.util.UUID;
|
@ -14,8 +14,8 @@ import org.junit.Test;
|
||||
import org.junit.runner.RunWith;
|
||||
import org.powermock.core.classloader.annotations.PrepareForTest;
|
||||
import org.powermock.modules.junit4.PowerMockRunner;
|
||||
import test.java.utils.MockUtils;
|
||||
import test.java.utils.TestInit;
|
||||
import test.java.utils.MockUtils;
|
||||
|
||||
import java.net.InetAddress;
|
||||
import java.net.UnknownHostException;
|
@ -29,18 +29,18 @@ import java.util.List;
|
||||
import java.util.UUID;
|
||||
import java.util.stream.Collectors;
|
||||
|
||||
import static junit.framework.TestCase.assertFalse;
|
||||
import static org.junit.Assert.assertEquals;
|
||||
import static org.junit.Assert.assertTrue;
|
||||
|
||||
@RunWith(PowerMockRunner.class)
|
||||
@PrepareForTest(JavaPlugin.class)
|
||||
public class DatabaseCommitTest {
|
||||
|
||||
|
||||
private Plan plan;
|
||||
private Database db;
|
||||
private int rows;
|
||||
|
||||
|
||||
@Before
|
||||
public void setUp() throws Exception {
|
||||
TestInit t = TestInit.init();
|
||||
@ -89,7 +89,7 @@ public class DatabaseCommitTest {
|
||||
db.saveCommandUse(c);
|
||||
db.close();
|
||||
db.init();
|
||||
assertTrue(!db.getCommandUse().isEmpty());
|
||||
assertFalse(db.getCommandUse().isEmpty());
|
||||
}
|
||||
|
||||
@Test
|
||||
@ -99,7 +99,7 @@ public class DatabaseCommitTest {
|
||||
db.getTpsTable().saveTPSData(tps);
|
||||
db.close();
|
||||
db.init();
|
||||
assertTrue(!db.getTpsTable().getTPSData().isEmpty());
|
||||
assertFalse(db.getTpsTable().getTPSData().isEmpty());
|
||||
}
|
||||
|
||||
@Test
|
||||
@ -109,7 +109,7 @@ public class DatabaseCommitTest {
|
||||
db.saveUserData(userData);
|
||||
db.close();
|
||||
db.init();
|
||||
assertTrue(!db.getUserDataForUUIDS(Collections.singletonList(MockUtils.getPlayerUUID())).isEmpty());
|
||||
assertFalse(db.getUserDataForUUIDS(Collections.singletonList(MockUtils.getPlayerUUID())).isEmpty());
|
||||
}
|
||||
|
||||
@Test
|
||||
@ -120,17 +120,16 @@ public class DatabaseCommitTest {
|
||||
db.saveMultipleUserData(data);
|
||||
db.close();
|
||||
db.init();
|
||||
assertTrue(!db.getUserDataForUUIDS(uuids).isEmpty());
|
||||
assertFalse(db.getUserDataForUUIDS(uuids).isEmpty());
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testCommitToDBFile5() throws SQLException, PassEncryptUtil.CannotPerformOperationException {
|
||||
db.init();
|
||||
List<UserData> data = RandomData.randomUserData();
|
||||
WebUser webUser = new WebUser("Test", "SHA1:rioegnorgiengoieng:oiegnoeigneo:352", 0);
|
||||
db.getSecurityTable().addNewUser(webUser);
|
||||
db.close();
|
||||
db.init();
|
||||
assertTrue(webUser.equals(db.getSecurityTable().getWebUser("Test")));
|
||||
assertEquals(webUser, db.getSecurityTable().getWebUser("Test"));
|
||||
}
|
||||
}
|
@ -5,14 +5,14 @@ import org.bukkit.Location;
|
||||
import org.bukkit.World;
|
||||
import org.bukkit.plugin.java.JavaPlugin;
|
||||
import org.junit.Before;
|
||||
import org.junit.Ignore;
|
||||
import org.junit.Test;
|
||||
import org.junit.runner.RunWith;
|
||||
import org.powermock.core.classloader.annotations.PrepareForTest;
|
||||
import org.powermock.modules.junit4.PowerMockRunner;
|
||||
import test.java.utils.MockUtils;
|
||||
import test.java.utils.TestInit;
|
||||
import test.java.utils.MockUtils;
|
||||
|
||||
import java.text.SimpleDateFormat;
|
||||
import java.util.Date;
|
||||
|
||||
import static org.junit.Assert.*;
|
||||
@ -63,26 +63,30 @@ public class FormatUtilsTest {
|
||||
assertEquals(expResult, result);
|
||||
}
|
||||
|
||||
/**
|
||||
*
|
||||
*/
|
||||
@Test
|
||||
@Ignore
|
||||
public void testFormatTimeStamp() {
|
||||
SimpleDateFormat dateFormat = new SimpleDateFormat("MMM dd',' HH':'mm");
|
||||
|
||||
Date date = new Date();
|
||||
date.setTime(0);
|
||||
|
||||
String expResult = dateFormat.format(date);
|
||||
|
||||
long epochZero = 0L;
|
||||
String expResult = "Jan 01, 01:00";
|
||||
String result = FormatUtils.formatTimeStamp(epochZero);
|
||||
assertEquals(expResult, result);
|
||||
}
|
||||
|
||||
/**
|
||||
*
|
||||
*/
|
||||
@Test
|
||||
@Ignore
|
||||
public void testFormatTimeStampYear() {
|
||||
SimpleDateFormat dateFormat = new SimpleDateFormat("MMM dd YYYY',' HH':'mm");
|
||||
|
||||
Date date = new Date();
|
||||
date.setTime(0);
|
||||
|
||||
String expResult = dateFormat.format(date);
|
||||
|
||||
long epochZero = 0L;
|
||||
String expResult = "Jan 01 1970, 01:00";
|
||||
String result = FormatUtils.formatTimeStampYear(epochZero);
|
||||
assertEquals(expResult, result);
|
||||
}
|
@ -43,9 +43,6 @@ public class MiscUtilsTest {
|
||||
public void setUp() throws Exception {
|
||||
}
|
||||
|
||||
/**
|
||||
*
|
||||
*/
|
||||
@Test
|
||||
public void testGetPlayerDisplaynameArgsPerm() {
|
||||
String[] args = new String[]{"Rsl1122", "Test"};
|
||||
@ -55,9 +52,6 @@ public class MiscUtilsTest {
|
||||
assertEquals(expResult, result);
|
||||
}
|
||||
|
||||
/**
|
||||
*
|
||||
*/
|
||||
@Test
|
||||
public void testGetPlayerDisplaynameArgsNoPerm() {
|
||||
String[] args = new String[]{"Rsl1122", "Test"};
|
||||
@ -67,9 +61,6 @@ public class MiscUtilsTest {
|
||||
assertEquals(expResult, result);
|
||||
}
|
||||
|
||||
/**
|
||||
*
|
||||
*/
|
||||
@Test
|
||||
public void testGetPlayerDisplaynameNoArgsPerm() {
|
||||
String[] args = new String[]{};
|
||||
@ -79,9 +70,6 @@ public class MiscUtilsTest {
|
||||
assertEquals(expResult, result);
|
||||
}
|
||||
|
||||
/**
|
||||
*
|
||||
*/
|
||||
@Test
|
||||
public void testGetPlayerDisplaynameNoArgsNoPerm() {
|
||||
String[] args = new String[]{};
|
||||
@ -91,9 +79,6 @@ public class MiscUtilsTest {
|
||||
assertEquals(expResult, result);
|
||||
}
|
||||
|
||||
/**
|
||||
*
|
||||
*/
|
||||
@Test
|
||||
public void testGetPlayerDisplaynameOwnNameNoPerm() {
|
||||
String[] args = new String[]{"testname2"};
|
||||
@ -103,9 +88,6 @@ public class MiscUtilsTest {
|
||||
assertEquals(expResult, result);
|
||||
}
|
||||
|
||||
/**
|
||||
*
|
||||
*/
|
||||
@Test
|
||||
public void testGetPlayerDisplaynameConsole() {
|
||||
String[] args = new String[]{"TestConsoleSender"};
|
||||
@ -115,9 +97,6 @@ public class MiscUtilsTest {
|
||||
assertEquals(expResult, result);
|
||||
}
|
||||
|
||||
/**
|
||||
*
|
||||
*/
|
||||
@Test
|
||||
@Ignore("DB mock")
|
||||
public void testGetMatchingDisplaynames() throws Exception {
|
||||
@ -131,9 +110,6 @@ public class MiscUtilsTest {
|
||||
assertEquals(exp2, result.get(1));
|
||||
}
|
||||
|
||||
/**
|
||||
*
|
||||
*/
|
||||
@Test
|
||||
@Ignore("DB mock")
|
||||
public void testGetMatchingDisplaynames2() throws Exception {
|
@ -55,7 +55,7 @@ public class NewPlayerCreatorTest {
|
||||
*
|
||||
*/
|
||||
@Test
|
||||
public void testCreateNewPlayer_Player() {
|
||||
public void testCreateNewPlayer() {
|
||||
IOfflinePlayer p = BukkitOfflinePlayer.wrap(MockUtils.mockPlayer2());
|
||||
UserData result = NewPlayerCreator.createNewOfflinePlayer(p);
|
||||
UserData exp = new UserData(p);
|
||||
@ -73,7 +73,7 @@ public class NewPlayerCreatorTest {
|
||||
*
|
||||
*/
|
||||
@Test
|
||||
public void testCreateNewPlayer_OfflinePlayer() {
|
||||
public void testCreateNewOfflinePlayer() {
|
||||
IPlayer p = BukkitPlayer.wrap(MockUtils.mockPlayer2());
|
||||
UserData result = NewPlayerCreator.createNewPlayer(p);
|
||||
UserData exp = new UserData(p);
|
||||
@ -91,7 +91,7 @@ public class NewPlayerCreatorTest {
|
||||
*
|
||||
*/
|
||||
@Test
|
||||
public void testCreateNewPlayer_OfflinePlayer_Gamemode() {
|
||||
public void testCreateNewPlayerWithGameMode() {
|
||||
IOfflinePlayer p = BukkitOfflinePlayer.wrap(MockUtils.mockPlayer());
|
||||
UserData result = NewPlayerCreator.createNewPlayer(p, Gamemode.CREATIVE);
|
||||
UserData exp = new UserData(p);
|
@ -56,7 +56,7 @@ public class MathUtilsTest {
|
||||
*
|
||||
*/
|
||||
@Test
|
||||
public void testAverageLong_Collection() {
|
||||
public void testAverageLongCollection() {
|
||||
List<Long> l = new ArrayList<>();
|
||||
double exp = 10;
|
||||
l.add(0L);
|
||||
@ -154,4 +154,12 @@ public class MathUtilsTest {
|
||||
double result = MathUtils.sumDouble(l.stream());
|
||||
assertTrue(result + "/" + exp, Double.compare(exp, result) == 0);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testRoundDouble() {
|
||||
double exp = 412.5123125123;
|
||||
double roundedExp = MathUtils.round(exp);
|
||||
|
||||
assertTrue("", Double.compare(412.51, roundedExp) == 0);
|
||||
}
|
||||
}
|
@ -20,8 +20,6 @@ import static org.junit.Assert.assertEquals;
|
||||
|
||||
public class ComparatorTest {
|
||||
|
||||
private Random r = new Random();
|
||||
|
||||
@Test
|
||||
public void testHandlingInfoComparator() {
|
||||
List<HandlingInfo> test = RandomData.randomHandlingInfo();
|
@ -31,9 +31,6 @@ public class RandomData {
|
||||
return test;
|
||||
}
|
||||
|
||||
/**
|
||||
* Random enough.
|
||||
*/
|
||||
public static String randomString(int size) {
|
||||
return RandomStringUtils.random(size);
|
||||
}
|
Loading…
Reference in New Issue
Block a user