Test and fix top_ placeholders

Affects issues:
- Fixed #3369
This commit is contained in:
Aurora Lahtela 2024-01-21 20:08:46 +02:00
parent c8d0cc91b6
commit 8356a0d52e
2 changed files with 49 additions and 7 deletions

View File

@ -38,6 +38,7 @@ import java.util.Arrays;
import java.util.List; import java.util.List;
import java.util.Optional; import java.util.Optional;
import java.util.concurrent.TimeUnit; import java.util.concurrent.TimeUnit;
import java.util.function.Function;
import static com.djrapitops.plan.utilities.MiscUtils.*; import static com.djrapitops.plan.utilities.MiscUtils.*;
@ -220,14 +221,14 @@ public class ServerPlaceHolders implements Placeholders {
for (int i = 0; i < 10; i++) { for (int i = 0; i < 10; i++) {
for (TopCategoryQuery<Long> query : queries) { for (TopCategoryQuery<Long> query : queries) {
final int nth = i; final int nth = i;
placeholders.registerStatic(String.format("top_%s_%s_%s", query.getCategory(), query.getTimeSpan(), nth), placeholders.registerStatic(String.format("top_%s_%s_%s", query.getCategory(), query.getTimeSpan(), nth + 1),
parameters -> database.query(query.getQuery(nth, parameters)) parameters -> database.query(query.getQuery(nth, parameters))
.map(TopListQueries.TopListEntry::getPlayerName) .map(TopListQueries.TopListEntry::getPlayerName)
.orElse("-")); .orElse("-"));
placeholders.registerStatic(String.format("top_%s_%s_%s_value", query.getCategory(), query.getTimeSpan(), nth), placeholders.registerStatic(String.format("top_%s_%s_%s_value", query.getCategory(), query.getTimeSpan(), nth + 1),
parameters -> database.query(query.getQuery(nth, parameters)) parameters -> database.query(query.getQuery(nth, parameters))
.map(TopListQueries.TopListEntry::getValue) .map(TopListQueries.TopListEntry::getValue)
.map(formatters.timeAmount()) .map(query.getCategory().equals("player_kills") ? Function.identity() : formatters.timeAmount())
.orElse("-")); .orElse("-"));
} }
} }

View File

@ -17,6 +17,8 @@
package com.djrapitops.plan.placeholder; package com.djrapitops.plan.placeholder;
import com.djrapitops.plan.PlanSystem; import com.djrapitops.plan.PlanSystem;
import com.djrapitops.plan.delivery.domain.ServerIdentifier;
import com.djrapitops.plan.gathering.domain.*;
import com.djrapitops.plan.identification.ServerUUID; import com.djrapitops.plan.identification.ServerUUID;
import com.djrapitops.plan.storage.database.Database; import com.djrapitops.plan.storage.database.Database;
import com.djrapitops.plan.storage.database.transactions.events.StoreServerPlayerTransaction; import com.djrapitops.plan.storage.database.transactions.events.StoreServerPlayerTransaction;
@ -31,11 +33,10 @@ import utilities.mocks.PluginMockComponent;
import java.nio.file.Files; import java.nio.file.Files;
import java.nio.file.Path; import java.nio.file.Path;
import java.util.Collection; import java.util.*;
import java.util.Collections; import java.util.concurrent.ExecutionException;
import java.util.List;
import java.util.UUID;
import java.util.stream.Collectors; import java.util.stream.Collectors;
import java.util.stream.IntStream;
import static org.junit.jupiter.api.Assertions.*; import static org.junit.jupiter.api.Assertions.*;
@ -194,4 +195,44 @@ class PlanPlaceholdersTest {
.collect(Collectors.toList()); .collect(Collectors.toList());
} }
@TestFactory
@DisplayName("Top Player Kills Total placeholders work")
Collection<DynamicTest> topKillsPlaceholdersWork() {
return IntStream.range(1, 11)
.mapToObj(integer -> "top_player_kills_total_" + integer + "_value")
.map(placeholder -> DynamicTest.dynamicTest("'" + placeholder + "' returns something", () -> {
storeKillers();
String result = underTest.onPlaceholderRequest(null, placeholder, List.of(playerUUID.toString()));
System.out.println("Placeholder '" + placeholder + "' was replaced with: '" + result + "'");
assertNotNull(result);
assertNotEquals(placeholder, result);
}))
.collect(Collectors.toList());
}
private void storeKillers() throws ExecutionException, InterruptedException {
Database database = component.system().getDatabaseSystem().getDatabase();
List<UUID> randomUUIDs = IntStream.of(11).mapToObj(i -> UUID.randomUUID()).toList();
for (UUID playerUUID : randomUUIDs) {
database.executeTransaction(new StoreServerPlayerTransaction(playerUUID, System::currentTimeMillis, playerUUID.toString(), serverUUID, () -> ""))
.get();
DataMap dataMap = new DataMap();
List<PlayerKill> playerKills = new ArrayList<>();
for (int i = 0; i < RandomData.randomInt(3, 20); i++) {
UUID victim = randomUUIDs.get(RandomData.randomInt(0, randomUUIDs.size()));
playerKills.add(new PlayerKill(
new PlayerKill.Killer(playerUUID, playerUUID.toString()),
new PlayerKill.Victim(victim, victim.toString()),
new ServerIdentifier(serverUUID, TestConstants.SERVER_NAME),
"Sword",
System.currentTimeMillis()
));
}
dataMap.put(PlayerKills.class, new PlayerKills(playerKills));
dataMap.put(WorldTimes.class, new WorldTimes());
database.executeTransaction(new StoreSessionTransaction(new FinishedSession(playerUUID, serverUUID, System.currentTimeMillis(), System.currentTimeMillis(), 0, dataMap)))
.get();
}
}
} }