Test case against ShutdownSave doing the bad save in #1424

- Rules out ShutdownSave code from the cause of the bug.
This commit is contained in:
Risto Lahtela 2020-05-05 10:23:53 +03:00
parent b7e1261597
commit 95cd4acb7d
3 changed files with 35 additions and 3 deletions

View File

@ -111,7 +111,7 @@ public abstract class ServerShutdownSave {
return saveSessions(activeSessions, database); return saveSessions(activeSessions, database);
} }
private void prepareSessionsForStorage(Map<UUID, Session> activeSessions, long now) { void prepareSessionsForStorage(Map<UUID, Session> activeSessions, long now) {
for (Session session : activeSessions.values()) { for (Session session : activeSessions.values()) {
Optional<Long> end = session.getValue(SessionKeys.END); Optional<Long> end = session.getValue(SessionKeys.END);
if (!end.isPresent()) { if (!end.isPresent()) {

View File

@ -16,6 +16,7 @@
*/ */
package com.djrapitops.plan.gathering; package com.djrapitops.plan.gathering;
import com.djrapitops.plan.delivery.domain.keys.SessionKeys;
import com.djrapitops.plan.gathering.cache.SessionCache; import com.djrapitops.plan.gathering.cache.SessionCache;
import com.djrapitops.plan.gathering.domain.GMTimes; import com.djrapitops.plan.gathering.domain.GMTimes;
import com.djrapitops.plan.gathering.domain.Session; import com.djrapitops.plan.gathering.domain.Session;
@ -36,16 +37,17 @@ import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Test; import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.extension.ExtendWith; import org.junit.jupiter.api.extension.ExtendWith;
import org.junit.jupiter.api.io.TempDir; import org.junit.jupiter.api.io.TempDir;
import utilities.RandomData;
import utilities.TestConstants; import utilities.TestConstants;
import utilities.dagger.DaggerPlanPluginComponent; import utilities.dagger.DaggerPlanPluginComponent;
import utilities.dagger.PlanPluginComponent; import utilities.dagger.PlanPluginComponent;
import utilities.mocks.PlanPluginMocker; import utilities.mocks.PlanPluginMocker;
import java.nio.file.Path; import java.nio.file.Path;
import java.util.Map;
import java.util.UUID; import java.util.UUID;
import static org.junit.jupiter.api.Assertions.assertFalse; import static org.junit.jupiter.api.Assertions.*;
import static org.junit.jupiter.api.Assertions.assertTrue;
import static org.mockito.Mockito.mock; import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.when; import static org.mockito.Mockito.when;
@ -151,4 +153,21 @@ class ShutdownSaveTest {
sessionCache.cacheSession(playerUUID, session); sessionCache.cacheSession(playerUUID, session);
} }
@Test
public void endedSessionsHaveSameEndTime() {
for (int i = 0; i < 100; i++) {
UUID playerUUID = UUID.randomUUID();
Session session = RandomData.randomUnfinishedSession(
TestConstants.SERVER_UUID, new String[]{"w1", "w2"}, playerUUID
);
sessionCache.cacheSession(playerUUID, session);
}
long endTime = System.currentTimeMillis();
Map<UUID, Session> activeSessions = SessionCache.getActiveSessions();
underTest.prepareSessionsForStorage(activeSessions, endTime);
for (Session session : activeSessions.values()) {
assertEquals(endTime, session.getUnsafe(SessionKeys.END), () -> "One of the sessions had differing end time");
}
}
} }

View File

@ -114,6 +114,19 @@ public class RandomData {
return session; return session;
} }
public static List<Session> randomUnfinishedSessions(UUID serverUUID, String[] worlds, UUID... uuids) {
return pickMultiple(randomInt(5, 50), () -> randomUnfinishedSession(serverUUID, worlds, uuids));
}
public static Session randomUnfinishedSession(UUID serverUUID, String[] worlds, UUID... uuids) {
Session session = new Session(uuids[0], serverUUID, RandomData.randomTime(), pickAtRandom(worlds), randomGameMode());
session.setWorldTimes(RandomData.randomWorldTimes(worlds));
if (uuids.length >= 2) {
session.setPlayerKills(RandomData.randomKills(pickAtRandom(Arrays.copyOfRange(uuids, 1, uuids.length))));
}
return session;
}
public static List<Point> randomPoints() { public static List<Point> randomPoints() {
List<Point> test = new ArrayList<>(); List<Point> test = new ArrayList<>();
for (int i = 0; i < 20; i++) { for (int i = 0; i < 20; i++) {