mirror of
https://github.com/plan-player-analytics/Plan.git
synced 2025-01-08 17:37:34 +01:00
Fixed some tests not closing resources properly
This commit is contained in:
parent
a14c97002c
commit
040c2c4f4b
@ -38,9 +38,9 @@ import utilities.mocks.objects.TestLogger;
|
|||||||
import utilities.mocks.objects.TestRunnableFactory;
|
import utilities.mocks.objects.TestRunnableFactory;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.FileInputStream;
|
|
||||||
import java.io.FileNotFoundException;
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.nio.file.Files;
|
||||||
|
|
||||||
import static org.mockito.Mockito.doReturn;
|
import static org.mockito.Mockito.doReturn;
|
||||||
|
|
||||||
@ -90,11 +90,10 @@ public class PlanBukkitMocker extends Mocker {
|
|||||||
}
|
}
|
||||||
|
|
||||||
PlanBukkitMocker withPluginDescription() {
|
PlanBukkitMocker withPluginDescription() {
|
||||||
try {
|
try (InputStream in = Files.newInputStream(getFile("/plugin.yml").toPath())) {
|
||||||
File pluginYml = getFile("/plugin.yml");
|
PluginDescriptionFile description = new PluginDescriptionFile(in);
|
||||||
PluginDescriptionFile description = new PluginDescriptionFile(new FileInputStream(pluginYml));
|
|
||||||
doReturn(description).when(planMock).getDescription();
|
doReturn(description).when(planMock).getDescription();
|
||||||
} catch (FileNotFoundException | InvalidDescriptionException e) {
|
} catch (IOException | InvalidDescriptionException e) {
|
||||||
System.out.println("Error while setting plugin description");
|
System.out.println("Error while setting plugin description");
|
||||||
}
|
}
|
||||||
return this;
|
return this;
|
||||||
|
@ -694,27 +694,59 @@ public interface DatabaseTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
default void testBackupAndRestore() throws Exception {
|
default void testBackupAndRestoreSQLite() throws Exception {
|
||||||
|
File tempFile = Files.createTempFile(system().getPlanFiles().getDataFolder().toPath(), "backup-", ".db").toFile();
|
||||||
|
tempFile.deleteOnExit();
|
||||||
|
SQLiteDB backup = system().getDatabaseSystem().getSqLiteFactory().usingFile(tempFile);
|
||||||
|
backup.setTransactionExecutorServiceProvider(MoreExecutors::newDirectExecutorService);
|
||||||
|
try {
|
||||||
|
backup.init();
|
||||||
|
|
||||||
|
saveAllData();
|
||||||
|
|
||||||
|
backup.executeTransaction(new BackupCopyTransaction(db(), backup));
|
||||||
|
|
||||||
|
assertQueryResultIsEqual(db(), backup, BaseUserQueries.fetchAllBaseUsers());
|
||||||
|
assertQueryResultIsEqual(db(), backup, UserInfoQueries.fetchAllUserInformation());
|
||||||
|
assertQueryResultIsEqual(db(), backup, NicknameQueries.fetchAllNicknameData());
|
||||||
|
assertQueryResultIsEqual(db(), backup, GeoInfoQueries.fetchAllGeoInformation());
|
||||||
|
assertQueryResultIsEqual(db(), backup, SessionQueries.fetchAllSessions());
|
||||||
|
assertQueryResultIsEqual(db(), backup, LargeFetchQueries.fetchAllCommandUsageData());
|
||||||
|
assertQueryResultIsEqual(db(), backup, LargeFetchQueries.fetchAllWorldNames());
|
||||||
|
assertQueryResultIsEqual(db(), backup, LargeFetchQueries.fetchAllTPSData());
|
||||||
|
assertQueryResultIsEqual(db(), backup, ServerQueries.fetchPlanServerInformation());
|
||||||
|
assertQueryResultIsEqual(db(), backup, WebUserQueries.fetchAllPlanWebUsers());
|
||||||
|
} finally {
|
||||||
|
backup.close();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
default void testBackupAndRestoreH2() throws Exception {
|
||||||
File tempFile = Files.createTempFile(system().getPlanFiles().getDataFolder().toPath(), "backup-", ".db").toFile();
|
File tempFile = Files.createTempFile(system().getPlanFiles().getDataFolder().toPath(), "backup-", ".db").toFile();
|
||||||
tempFile.deleteOnExit();
|
tempFile.deleteOnExit();
|
||||||
H2DB backup = system().getDatabaseSystem().getH2Factory().usingFile(tempFile);
|
H2DB backup = system().getDatabaseSystem().getH2Factory().usingFile(tempFile);
|
||||||
backup.setTransactionExecutorServiceProvider(MoreExecutors::newDirectExecutorService);
|
backup.setTransactionExecutorServiceProvider(MoreExecutors::newDirectExecutorService);
|
||||||
backup.init();
|
try {
|
||||||
|
backup.init();
|
||||||
|
|
||||||
saveAllData();
|
saveAllData();
|
||||||
|
|
||||||
backup.executeTransaction(new BackupCopyTransaction(db(), backup));
|
backup.executeTransaction(new BackupCopyTransaction(db(), backup));
|
||||||
|
|
||||||
assertQueryResultIsEqual(db(), backup, BaseUserQueries.fetchAllBaseUsers());
|
assertQueryResultIsEqual(db(), backup, BaseUserQueries.fetchAllBaseUsers());
|
||||||
assertQueryResultIsEqual(db(), backup, UserInfoQueries.fetchAllUserInformation());
|
assertQueryResultIsEqual(db(), backup, UserInfoQueries.fetchAllUserInformation());
|
||||||
assertQueryResultIsEqual(db(), backup, NicknameQueries.fetchAllNicknameData());
|
assertQueryResultIsEqual(db(), backup, NicknameQueries.fetchAllNicknameData());
|
||||||
assertQueryResultIsEqual(db(), backup, GeoInfoQueries.fetchAllGeoInformation());
|
assertQueryResultIsEqual(db(), backup, GeoInfoQueries.fetchAllGeoInformation());
|
||||||
assertQueryResultIsEqual(db(), backup, SessionQueries.fetchAllSessions());
|
assertQueryResultIsEqual(db(), backup, SessionQueries.fetchAllSessions());
|
||||||
assertQueryResultIsEqual(db(), backup, LargeFetchQueries.fetchAllCommandUsageData());
|
assertQueryResultIsEqual(db(), backup, LargeFetchQueries.fetchAllCommandUsageData());
|
||||||
assertQueryResultIsEqual(db(), backup, LargeFetchQueries.fetchAllWorldNames());
|
assertQueryResultIsEqual(db(), backup, LargeFetchQueries.fetchAllWorldNames());
|
||||||
assertQueryResultIsEqual(db(), backup, LargeFetchQueries.fetchAllTPSData());
|
assertQueryResultIsEqual(db(), backup, LargeFetchQueries.fetchAllTPSData());
|
||||||
assertQueryResultIsEqual(db(), backup, ServerQueries.fetchPlanServerInformation());
|
assertQueryResultIsEqual(db(), backup, ServerQueries.fetchPlanServerInformation());
|
||||||
assertQueryResultIsEqual(db(), backup, WebUserQueries.fetchAllPlanWebUsers());
|
assertQueryResultIsEqual(db(), backup, WebUserQueries.fetchAllPlanWebUsers());
|
||||||
|
} finally {
|
||||||
|
backup.close();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
default <T> void assertQueryResultIsEqual(Database one, Database two, Query<T> query) {
|
default <T> void assertQueryResultIsEqual(Database one, Database two, Query<T> query) {
|
||||||
|
@ -25,9 +25,6 @@ import com.djrapitops.plan.system.PlanSystem;
|
|||||||
import com.djrapitops.plan.system.database.DBSystem;
|
import com.djrapitops.plan.system.database.DBSystem;
|
||||||
import com.djrapitops.plan.system.settings.config.PlanConfig;
|
import com.djrapitops.plan.system.settings.config.PlanConfig;
|
||||||
import com.djrapitops.plan.system.settings.paths.WebserverSettings;
|
import com.djrapitops.plan.system.settings.paths.WebserverSettings;
|
||||||
import com.djrapitops.plan.system.webserver.cache.PageId;
|
|
||||||
import com.djrapitops.plan.system.webserver.cache.ResponseCache;
|
|
||||||
import com.jayway.awaitility.Awaitility;
|
|
||||||
import extension.SeleniumExtension;
|
import extension.SeleniumExtension;
|
||||||
import org.junit.jupiter.api.AfterAll;
|
import org.junit.jupiter.api.AfterAll;
|
||||||
import org.junit.jupiter.api.AfterEach;
|
import org.junit.jupiter.api.AfterEach;
|
||||||
@ -44,7 +41,6 @@ import utilities.mocks.PluginMockComponent;
|
|||||||
|
|
||||||
import java.nio.file.Path;
|
import java.nio.file.Path;
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
import java.util.concurrent.TimeUnit;
|
|
||||||
|
|
||||||
import static org.junit.jupiter.api.Assertions.assertFalse;
|
import static org.junit.jupiter.api.Assertions.assertFalse;
|
||||||
|
|
||||||
@ -124,17 +120,6 @@ class JSErrorRegressionTest {
|
|||||||
@Test
|
@Test
|
||||||
void serverPageDoesNotHaveJavascriptErrors(WebDriver driver) {
|
void serverPageDoesNotHaveJavascriptErrors(WebDriver driver) {
|
||||||
System.out.println("Testing Server Page");
|
System.out.println("Testing Server Page");
|
||||||
// Open the page that has refreshing info
|
|
||||||
driver.get("http://localhost:" + TEST_PORT_NUMBER + "/server");
|
|
||||||
assertNo500Error(driver);
|
|
||||||
|
|
||||||
// Wait until Plan caches analysis results
|
|
||||||
Awaitility.await()
|
|
||||||
.atMost(10, TimeUnit.SECONDS)
|
|
||||||
.until(() -> ResponseCache.loadResponse(PageId.SERVER.of(serverUUID)) != null);
|
|
||||||
|
|
||||||
// Open the page with analysis stuff
|
|
||||||
SeleniumExtension.newTab(driver);
|
|
||||||
driver.get("http://localhost:" + TEST_PORT_NUMBER + "/server");
|
driver.get("http://localhost:" + TEST_PORT_NUMBER + "/server");
|
||||||
assertNo500Error(driver);
|
assertNo500Error(driver);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user