mirror of
https://github.com/correl/mage.git
synced 2024-11-25 03:00:11 +00:00
Tests: improved load tests (fixed AI names, improved logs, improved custom decks support, related to #10154);
This commit is contained in:
parent
a9f1e15168
commit
81d9c099fb
3 changed files with 137 additions and 93 deletions
|
@ -30,8 +30,11 @@ public class LoadCallbackClient implements CallbackClient {
|
||||||
|
|
||||||
private GameView gameView;
|
private GameView gameView;
|
||||||
|
|
||||||
public LoadCallbackClient(boolean joinGameChat) {
|
private final String logsPrefix;
|
||||||
|
|
||||||
|
public LoadCallbackClient(boolean joinGameChat, String logsPrefix) {
|
||||||
this.joinGameChat = joinGameChat;
|
this.joinGameChat = joinGameChat;
|
||||||
|
this.logsPrefix = logsPrefix;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -60,7 +63,7 @@ public class LoadCallbackClient implements CallbackClient {
|
||||||
|
|
||||||
case CHATMESSAGE: {
|
case CHATMESSAGE: {
|
||||||
ChatMessage message = (ChatMessage) callback.getData();
|
ChatMessage message = (ChatMessage) callback.getData();
|
||||||
log.info("Chat message: " + message.getMessage());
|
log.info(getLogStartInfo() + "chat message: " + message.getMessage());
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -84,14 +87,14 @@ public class LoadCallbackClient implements CallbackClient {
|
||||||
|
|
||||||
case SHOW_USERMESSAGE: {
|
case SHOW_USERMESSAGE: {
|
||||||
List<String> messageData = (List<String>) callback.getData();
|
List<String> messageData = (List<String>) callback.getData();
|
||||||
log.info("Warning message: " + String.join(" - ", messageData));
|
log.info(getLogStartInfo() + "warning message: " + String.join(" - ", messageData));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
case GAME_TARGET: {
|
case GAME_TARGET: {
|
||||||
GameClientMessage message = (GameClientMessage) callback.getData();
|
GameClientMessage message = (GameClientMessage) callback.getData();
|
||||||
this.gameView = message.getGameView();
|
this.gameView = message.getGameView();
|
||||||
log.info("Target: " + message.getMessage());
|
log.info(getLogStartInfo() + " target: " + message.getMessage());
|
||||||
switch (message.getMessage()) {
|
switch (message.getMessage()) {
|
||||||
case "Select a starting player":
|
case "Select a starting player":
|
||||||
session.sendPlayerUUID(gameId, playerId);
|
session.sendPlayerUUID(gameId, playerId);
|
||||||
|
@ -111,7 +114,7 @@ public class LoadCallbackClient implements CallbackClient {
|
||||||
|
|
||||||
case GAME_ASK: {
|
case GAME_ASK: {
|
||||||
GameClientMessage message = (GameClientMessage) callback.getData();
|
GameClientMessage message = (GameClientMessage) callback.getData();
|
||||||
log.info(getLogStartInfo() + "Ask: " + message.getMessage());
|
log.info(getLogStartInfo() + "ask: " + message.getMessage());
|
||||||
if (message.getMessage().startsWith("Mulligan")) {
|
if (message.getMessage().startsWith("Mulligan")) {
|
||||||
session.sendPlayerBoolean(gameId, false);
|
session.sendPlayerBoolean(gameId, false);
|
||||||
return;
|
return;
|
||||||
|
@ -123,7 +126,7 @@ public class LoadCallbackClient implements CallbackClient {
|
||||||
|
|
||||||
case GAME_SELECT: {
|
case GAME_SELECT: {
|
||||||
GameClientMessage message = (GameClientMessage) callback.getData();
|
GameClientMessage message = (GameClientMessage) callback.getData();
|
||||||
log.info("Select: " + message.getMessage());
|
log.info(getLogStartInfo() + "select: " + message.getMessage());
|
||||||
this.gameView = message.getGameView();
|
this.gameView = message.getGameView();
|
||||||
|
|
||||||
// concede
|
// concede
|
||||||
|
@ -149,14 +152,14 @@ public class LoadCallbackClient implements CallbackClient {
|
||||||
}
|
}
|
||||||
|
|
||||||
case GAME_OVER:
|
case GAME_OVER:
|
||||||
log.info(getLogStartInfo() + "Game over");
|
log.info(getLogStartInfo() + "game over");
|
||||||
gameOver = true;
|
gameOver = true;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case END_GAME_INFO:
|
case END_GAME_INFO:
|
||||||
GameEndView message = (GameEndView) callback.getData();
|
GameEndView message = (GameEndView) callback.getData();
|
||||||
this.gameResult = message.hasWon() ? "win" : "lose";
|
this.gameResult = message.hasWon() ? "win" : "lose";
|
||||||
log.info(getLogStartInfo() + "Game end info, " + this.gameResult);
|
log.info(getLogStartInfo() + "game end info, " + this.gameResult);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
// skip callbacks (no need to react)
|
// skip callbacks (no need to react)
|
||||||
|
@ -165,7 +168,7 @@ public class LoadCallbackClient implements CallbackClient {
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
log.error(getLogStartInfo() + "Unknown callback: " + callback.getMethod() + ", " + callback.getData().toString());
|
log.error(getLogStartInfo() + "unknown callback: " + callback.getMethod() + ", " + callback.getData().toString());
|
||||||
session.sendPlayerBoolean(gameId, false);
|
session.sendPlayerBoolean(gameId, false);
|
||||||
return;
|
return;
|
||||||
//break;
|
//break;
|
||||||
|
@ -187,16 +190,14 @@ public class LoadCallbackClient implements CallbackClient {
|
||||||
String mes = "";
|
String mes = "";
|
||||||
|
|
||||||
//throw new IllegalArgumentException("test exception");
|
//throw new IllegalArgumentException("test exception");
|
||||||
if (this.session != null) {
|
|
||||||
mes += session.getUserName() + ": ";
|
|
||||||
}
|
|
||||||
|
|
||||||
PlayerView p = getPlayer();
|
PlayerView p = getPlayer();
|
||||||
if (this.gameView != null && p != null && this.gameView.getStep() != null) {
|
if (this.gameView != null && p != null && this.gameView.getStep() != null) {
|
||||||
|
// never calls for client side client, cause it used as game's watcher, not a player
|
||||||
mes += "T" + this.gameView.getTurn() + "-" + this.gameView.getStep().getIndex() + ", L:" + p.getLibraryCount() + ", H:" + getPlayer().getHandCount() + ": ";
|
mes += "T" + this.gameView.getTurn() + "-" + this.gameView.getStep().getIndex() + ", L:" + p.getLibraryCount() + ", H:" + getPlayer().getHandCount() + ": ";
|
||||||
}
|
}
|
||||||
|
|
||||||
return mes;
|
return logsPrefix + ": " + mes;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setSession(Session session) {
|
public void setSession(Session session) {
|
||||||
|
@ -222,7 +223,7 @@ public class LoadCallbackClient implements CallbackClient {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (controlCount > 5) {
|
if (controlCount > 5) {
|
||||||
log.warn(getLogStartInfo() + "Game seems frozen. Sending boolean message to server.");
|
log.warn(getLogStartInfo() + "game seems frozen. Sending boolean message to server.");
|
||||||
session.sendPlayerBoolean(gameId, false);
|
session.sendPlayerBoolean(gameId, false);
|
||||||
controlCount = 0;
|
controlCount = 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -127,19 +127,19 @@ public class LoadTest {
|
||||||
|
|
||||||
// simple connection to server
|
// simple connection to server
|
||||||
// monitor other players
|
// monitor other players
|
||||||
LoadPlayer monitor = new LoadPlayer("mon");
|
LoadPlayer monitor = new LoadPlayer("mon", "mon");
|
||||||
Assert.assertTrue(monitor.session.isConnected());
|
Assert.assertTrue(monitor.session.isConnected());
|
||||||
int startUsersCount = monitor.getAllRoomUsers().size();
|
int startUsersCount = monitor.getAllRoomUsers().size();
|
||||||
int minimumSleepTime = 2000;
|
int minimumSleepTime = 2000;
|
||||||
|
|
||||||
// user 1
|
// user 1
|
||||||
LoadPlayer player1 = new LoadPlayer("1");
|
LoadPlayer player1 = new LoadPlayer("1", "p1 ");
|
||||||
Thread.sleep(minimumSleepTime);
|
Thread.sleep(minimumSleepTime);
|
||||||
Assert.assertEquals("Can't see users count change 1", startUsersCount + 1, monitor.getAllRoomUsers().size());
|
Assert.assertEquals("Can't see users count change 1", startUsersCount + 1, monitor.getAllRoomUsers().size());
|
||||||
Assert.assertNotNull("Can't find user 1", monitor.findUser(player1.userName));
|
Assert.assertNotNull("Can't find user 1", monitor.findUser(player1.userName));
|
||||||
|
|
||||||
// user 2
|
// user 2
|
||||||
LoadPlayer player2 = new LoadPlayer("2");
|
LoadPlayer player2 = new LoadPlayer("2", "p2 ");
|
||||||
Thread.sleep(minimumSleepTime);
|
Thread.sleep(minimumSleepTime);
|
||||||
Assert.assertEquals("Can't see users count change 2", startUsersCount + 2, monitor.getAllRoomUsers().size());
|
Assert.assertEquals("Can't see users count change 2", startUsersCount + 2, monitor.getAllRoomUsers().size());
|
||||||
Assert.assertNotNull("Can't find user 2", monitor.findUser(player2.userName));
|
Assert.assertNotNull("Can't find user 2", monitor.findUser(player2.userName));
|
||||||
|
@ -150,11 +150,11 @@ public class LoadTest {
|
||||||
public void test_TwoUsersPlayGameUntilEnd() {
|
public void test_TwoUsersPlayGameUntilEnd() {
|
||||||
|
|
||||||
// monitor other players
|
// monitor other players
|
||||||
LoadPlayer monitor = new LoadPlayer("mon");
|
LoadPlayer monitor = new LoadPlayer("mon", "mon");
|
||||||
|
|
||||||
// users
|
// users
|
||||||
LoadPlayer player1 = new LoadPlayer("user1");
|
LoadPlayer player1 = new LoadPlayer("user1", "p1");
|
||||||
LoadPlayer player2 = new LoadPlayer("user2");
|
LoadPlayer player2 = new LoadPlayer("user2", "p2");
|
||||||
|
|
||||||
// game by user 1
|
// game by user 1
|
||||||
GameTypeView gameType = prepareGameType(player1.session);
|
GameTypeView gameType = prepareGameType(player1.session);
|
||||||
|
@ -163,7 +163,7 @@ public class LoadTest {
|
||||||
UUID tableId = game.getTableId();
|
UUID tableId = game.getTableId();
|
||||||
Assert.assertEquals(player1.userName, game.getControllerName());
|
Assert.assertEquals(player1.userName, game.getControllerName());
|
||||||
|
|
||||||
DeckCardLists deckList = DeckTestUtils.buildRandomDeckAndInitCards("GR", true);
|
DeckCardLists deckList = loadGameDeck(1, "GR", true, TEST_AI_RANDOM_DECK_SETS);
|
||||||
Optional<TableView> checkGame;
|
Optional<TableView> checkGame;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -213,7 +213,7 @@ public class LoadTest {
|
||||||
Assert.assertFalse("need allowed sets", deckAllowedSets.isEmpty());
|
Assert.assertFalse("need allowed sets", deckAllowedSets.isEmpty());
|
||||||
|
|
||||||
// monitor and game source
|
// monitor and game source
|
||||||
LoadPlayer monitor = new LoadPlayer("mon", true);
|
LoadPlayer monitor = new LoadPlayer("mon", true, gameName + ", mon");
|
||||||
|
|
||||||
// game by monitor
|
// game by monitor
|
||||||
GameTypeView gameType = prepareGameType(monitor.session);
|
GameTypeView gameType = prepareGameType(monitor.session);
|
||||||
|
@ -222,19 +222,8 @@ public class LoadTest {
|
||||||
UUID tableId = game.getTableId();
|
UUID tableId = game.getTableId();
|
||||||
|
|
||||||
// deck load
|
// deck load
|
||||||
DeckCardLists deckListRandom = DeckTestUtils.buildRandomDeckAndInitCards(deckColors, false, deckAllowedSets);
|
DeckCardLists deckList1 = loadGameDeck(1, deckColors, false, deckAllowedSets);
|
||||||
DeckCardLists deckList1 = deckListRandom;
|
DeckCardLists deckList2 = loadGameDeck(2, deckColors, false, deckAllowedSets);
|
||||||
DeckCardLists deckList2 = deckListRandom;
|
|
||||||
if (!TEST_AI_CUSTOM_DECK_PATH_1.isEmpty()) {
|
|
||||||
deckList1 = DeckImporter.importDeckFromFile(TEST_AI_CUSTOM_DECK_PATH_1, false);
|
|
||||||
Assert.assertFalse("Can't load custom deck 1 from " + TEST_AI_CUSTOM_DECK_PATH_1, deckList1.getCards().isEmpty());
|
|
||||||
}
|
|
||||||
if (!TEST_AI_CUSTOM_DECK_PATH_2.isEmpty()) {
|
|
||||||
deckList2 = DeckImporter.importDeckFromFile(TEST_AI_CUSTOM_DECK_PATH_2, false);
|
|
||||||
Assert.assertFalse("Can't load custom deck 2 from " + TEST_AI_CUSTOM_DECK_PATH_2, deckList2.getCards().isEmpty());
|
|
||||||
}
|
|
||||||
|
|
||||||
Optional<TableView> checkGame;
|
|
||||||
|
|
||||||
// join AI
|
// join AI
|
||||||
Assert.assertTrue(monitor.session.joinTable(monitor.roomID, tableId, "ai_1", PlayerType.COMPUTER_MAD, 5, deckList1, ""));
|
Assert.assertTrue(monitor.session.joinTable(monitor.roomID, tableId, "ai_1", PlayerType.COMPUTER_MAD, 5, deckList1, ""));
|
||||||
|
@ -249,13 +238,18 @@ public class LoadTest {
|
||||||
while (true) {
|
while (true) {
|
||||||
GameView gameView = monitor.client.getLastGameView();
|
GameView gameView = monitor.client.getLastGameView();
|
||||||
|
|
||||||
checkGame = monitor.getTable(tableId);
|
TableView checkGame = monitor.getTable(tableId).orElse(null);
|
||||||
TableState state = checkGame.get().getTableState();
|
TableState state = (checkGame == null ? null : checkGame.getTableState());
|
||||||
|
|
||||||
logger.warn(checkGame.get().getTableName()
|
if (gameView != null && checkGame != null) {
|
||||||
+ (gameView != null ? ", turn " + gameView.getTurn() + ", " + gameView.getStep().toString() : "")
|
logger.warn(checkGame.getTableName() + ": ---");
|
||||||
+ (gameView != null ? ", active " + gameView.getActivePlayerName() : "")
|
logger.warn(String.format("%s: turn %d, step %s, state %s",
|
||||||
+ ", " + state);
|
checkGame.getTableName(),
|
||||||
|
gameView.getTurn(),
|
||||||
|
gameView.getStep().toString(),
|
||||||
|
state
|
||||||
|
));
|
||||||
|
}
|
||||||
|
|
||||||
if (state == TableState.FINISHED) {
|
if (state == TableState.FINISHED) {
|
||||||
gameResult.finish(gameView);
|
gameResult.finish(gameView);
|
||||||
|
@ -263,14 +257,27 @@ public class LoadTest {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!startToWatching && state == TableState.DUELING) {
|
if (!startToWatching && state == TableState.DUELING) {
|
||||||
Assert.assertTrue(monitor.session.watchGame(checkGame.get().getGames().iterator().next()));
|
Assert.assertTrue(monitor.session.watchGame(checkGame.getGames().iterator().next()));
|
||||||
startToWatching = true;
|
startToWatching = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (gameView != null) {
|
if (gameView != null && checkGame != null) {
|
||||||
for (PlayerView p : gameView.getPlayers()) {
|
gameView.getPlayers()
|
||||||
logger.info(p.getName() + " - Life=" + p.getLife() + "; Lib=" + p.getLibraryCount());
|
.stream()
|
||||||
|
.sorted(Comparator.comparing(PlayerView::getName))
|
||||||
|
.forEach(p -> {
|
||||||
|
String activeInfo = "";
|
||||||
|
if (Objects.equals(gameView.getActivePlayerId(), p.getPlayerId())) {
|
||||||
|
activeInfo = " (active)";
|
||||||
}
|
}
|
||||||
|
logger.info(String.format("%s, status: %s - Life=%d; Lib=%d;%s",
|
||||||
|
checkGame.getTableName(),
|
||||||
|
p.getName(),
|
||||||
|
p.getLife(),
|
||||||
|
p.getLibraryCount(),
|
||||||
|
activeInfo
|
||||||
|
));
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
@ -284,16 +291,20 @@ public class LoadTest {
|
||||||
@Test
|
@Test
|
||||||
@Ignore
|
@Ignore
|
||||||
public void test_TwoAIPlayGame_One() {
|
public void test_TwoAIPlayGame_One() {
|
||||||
LoadTestGameResult gameResult = new LoadTestGameResult(0, "test game", 0);
|
LoadTestGameResultsList gameResults = new LoadTestGameResultsList();
|
||||||
|
LoadTestGameResult gameResult = gameResults.createGame(0, "test game", 0);
|
||||||
playTwoAIGame("Single AI game", "WGUBR", TEST_AI_RANDOM_DECK_SETS, gameResult);
|
playTwoAIGame("Single AI game", "WGUBR", TEST_AI_RANDOM_DECK_SETS, gameResult);
|
||||||
|
|
||||||
|
printGameResults(gameResults);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@Ignore
|
@Ignore
|
||||||
public void test_TwoAIPlayGame_Multiple() {
|
public void test_TwoAIPlayGame_Multiple() {
|
||||||
|
// play multiple games with CLIENT side code (catch every GameView changes from the server)
|
||||||
|
|
||||||
int singleGameSID = 0; // set sid for same deck games, set 0 for random decks
|
int singleGameSID = 0; // set sid for same deck games, set 0 for random decks
|
||||||
int gamesAmount = 10; // games per run
|
int gamesAmount = 5; // games per run
|
||||||
|
|
||||||
// save random seeds for repeated results (in decks generating)
|
// save random seeds for repeated results (in decks generating)
|
||||||
List<Integer> seedsList = new ArrayList<>();
|
List<Integer> seedsList = new ArrayList<>();
|
||||||
|
@ -317,11 +328,7 @@ public class LoadTest {
|
||||||
playTwoAIGame(gameName, "WGUBR", TEST_AI_RANDOM_DECK_SETS, gameResult);
|
playTwoAIGame(gameName, "WGUBR", TEST_AI_RANDOM_DECK_SETS, gameResult);
|
||||||
}
|
}
|
||||||
|
|
||||||
// results
|
printGameResults(gameResults);
|
||||||
System.out.println();
|
|
||||||
gameResults.printResultHeader();
|
|
||||||
gameResults.printResultData();
|
|
||||||
gameResults.printResultTotal();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -331,9 +338,9 @@ public class LoadTest {
|
||||||
|
|
||||||
LoadGame game = new LoadGame(
|
LoadGame game = new LoadGame(
|
||||||
"game",
|
"game",
|
||||||
"thread",
|
"u",
|
||||||
DeckTestUtils.buildRandomDeckAndInitCards("GR", true, ""),
|
loadGameDeck(1, "GR", true, TEST_AI_RANDOM_DECK_SETS),
|
||||||
DeckTestUtils.buildRandomDeckAndInitCards("GR", true, "")
|
loadGameDeck(2, "GR", true, TEST_AI_RANDOM_DECK_SETS)
|
||||||
);
|
);
|
||||||
game.gameStart();
|
game.gameStart();
|
||||||
|
|
||||||
|
@ -355,9 +362,9 @@ public class LoadTest {
|
||||||
|
|
||||||
LoadGame game = new LoadGame(
|
LoadGame game = new LoadGame(
|
||||||
"game",
|
"game",
|
||||||
"thread",
|
"u",
|
||||||
DeckTestUtils.buildRandomDeckAndInitCards("GR", true, ""),
|
loadGameDeck(1, "GR", true, TEST_AI_RANDOM_DECK_SETS),
|
||||||
DeckTestUtils.buildRandomDeckAndInitCards("GR", true, "")
|
loadGameDeck(2, "GR", true, TEST_AI_RANDOM_DECK_SETS)
|
||||||
);
|
);
|
||||||
game.gameStart();
|
game.gameStart();
|
||||||
game.gameEnd(true); // abort -- close client thread
|
game.gameEnd(true); // abort -- close client thread
|
||||||
|
@ -371,9 +378,9 @@ public class LoadTest {
|
||||||
|
|
||||||
LoadGame game = new LoadGame(
|
LoadGame game = new LoadGame(
|
||||||
"game",
|
"game",
|
||||||
"thread",
|
"u",
|
||||||
DeckTestUtils.buildRandomDeckAndInitCards("GR", false, ""),
|
loadGameDeck(1, "GR", false, TEST_AI_RANDOM_DECK_SETS),
|
||||||
DeckTestUtils.buildRandomDeckAndInitCards("GR", false, "")
|
loadGameDeck(2, "GR", false, TEST_AI_RANDOM_DECK_SETS)
|
||||||
);
|
);
|
||||||
|
|
||||||
game.gameStart();
|
game.gameStart();
|
||||||
|
@ -384,13 +391,13 @@ public class LoadTest {
|
||||||
@Test
|
@Test
|
||||||
@Ignore
|
@Ignore
|
||||||
public void test_GameThreadWithConcede() {
|
public void test_GameThreadWithConcede() {
|
||||||
// simple game thread with with concede
|
// simple game thread with concede
|
||||||
|
|
||||||
LoadGame game = new LoadGame(
|
LoadGame game = new LoadGame(
|
||||||
"game",
|
"game",
|
||||||
"thread",
|
"u",
|
||||||
DeckTestUtils.buildRandomDeckAndInitCards("GR", true, ""),
|
loadGameDeck(1, "GR", true, TEST_AI_RANDOM_DECK_SETS),
|
||||||
DeckTestUtils.buildRandomDeckAndInitCards("GR", true, "")
|
loadGameDeck(2, "GR", true, TEST_AI_RANDOM_DECK_SETS)
|
||||||
);
|
);
|
||||||
game.gameStart();
|
game.gameStart();
|
||||||
|
|
||||||
|
@ -409,8 +416,10 @@ public class LoadTest {
|
||||||
@Test
|
@Test
|
||||||
@Ignore
|
@Ignore
|
||||||
public void test_MultipleGames() {
|
public void test_MultipleGames() {
|
||||||
// multiple games until finish
|
// play multiple games with SERVER side only,
|
||||||
final int MAX_GAMES = 50; // games to run
|
// all players on the server side, you don't get any GameView changes here
|
||||||
|
|
||||||
|
final int MAX_GAMES = 10; // games to run
|
||||||
final boolean START_GAMES_AT_ONCE = true; // set true to run ALL games parallel (e.g. test max parallel limit)
|
final boolean START_GAMES_AT_ONCE = true; // set true to run ALL games parallel (e.g. test max parallel limit)
|
||||||
|
|
||||||
Instant startTime = Instant.now();
|
Instant startTime = Instant.now();
|
||||||
|
@ -421,9 +430,9 @@ public class LoadTest {
|
||||||
for (int i = 1; i <= MAX_GAMES; i++) {
|
for (int i = 1; i <= MAX_GAMES; i++) {
|
||||||
LoadGame game = new LoadGame(
|
LoadGame game = new LoadGame(
|
||||||
"game" + i,
|
"game" + i,
|
||||||
"game" + i,
|
"u" + i,
|
||||||
DeckTestUtils.buildRandomDeckAndInitCards("GR", true, ""),
|
loadGameDeck(1, "GR", true, TEST_AI_RANDOM_DECK_SETS),
|
||||||
DeckTestUtils.buildRandomDeckAndInitCards("GR", true, "")
|
loadGameDeck(2, "GR", true, TEST_AI_RANDOM_DECK_SETS)
|
||||||
);
|
);
|
||||||
gamesList.add(game);
|
gamesList.add(game);
|
||||||
|
|
||||||
|
@ -528,14 +537,14 @@ public class LoadTest {
|
||||||
DeckCardLists deckList;
|
DeckCardLists deckList;
|
||||||
String lastGameResult = "";
|
String lastGameResult = "";
|
||||||
|
|
||||||
public LoadPlayer(String userPrefix) {
|
public LoadPlayer(String userPrefix, String logsPrefix) {
|
||||||
this(userPrefix, false);
|
this(userPrefix, false, logsPrefix);
|
||||||
}
|
}
|
||||||
|
|
||||||
public LoadPlayer(String userPrefix, boolean joinGameChat) {
|
public LoadPlayer(String userPrefix, boolean joinGameChat, String logsPrefix) {
|
||||||
this.userName = TEST_USER_NAME_GLOBAL_PREFIX + userPrefix + "_" + RandomUtil.nextInt(10000);
|
this.userName = TEST_USER_NAME_GLOBAL_PREFIX + userPrefix + "_" + RandomUtil.nextInt(10000);
|
||||||
this.connection = createSimpleConnection(this.userName);
|
this.connection = createSimpleConnection(this.userName);
|
||||||
this.client = new SimpleMageClient(joinGameChat);
|
this.client = new SimpleMageClient(joinGameChat, logsPrefix);
|
||||||
this.session = new SessionImpl(this.client);
|
this.session = new SessionImpl(this.client);
|
||||||
|
|
||||||
this.session.connect(this.connection);
|
this.session.connect(this.connection);
|
||||||
|
@ -617,18 +626,18 @@ public class LoadTest {
|
||||||
|
|
||||||
public LoadGame(String gameName, String playerPrefix) {
|
public LoadGame(String gameName, String playerPrefix) {
|
||||||
this(gameName, playerPrefix,
|
this(gameName, playerPrefix,
|
||||||
DeckTestUtils.buildRandomDeckAndInitCards("GR", true, ""),
|
loadGameDeck(1, "GR", true, TEST_AI_RANDOM_DECK_SETS),
|
||||||
DeckTestUtils.buildRandomDeckAndInitCards("GR", true, "")
|
loadGameDeck(2, "GR", true, TEST_AI_RANDOM_DECK_SETS)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
public LoadGame(String gameName, String playerPrefix, DeckCardLists deck1, DeckCardLists deck2) {
|
public LoadGame(String gameName, String playerPrefix, DeckCardLists deck1, DeckCardLists deck2) {
|
||||||
this.gameName = gameName;
|
this.gameName = gameName;
|
||||||
|
|
||||||
player1 = new LoadPlayer(playerPrefix + "_" + 1);
|
player1 = new LoadPlayer(playerPrefix + "_" + 1, playerPrefix + "_1");
|
||||||
player1.setDeckList(deck1);
|
player1.setDeckList(deck1);
|
||||||
|
|
||||||
player2 = new LoadPlayer(playerPrefix + "_" + 2);
|
player2 = new LoadPlayer(playerPrefix + "_" + 2, playerPrefix + "_2");
|
||||||
player2.setDeckList(deck2);
|
player2.setDeckList(deck2);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -719,7 +728,7 @@ public class LoadTest {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private class LoadTestGameResult {
|
private static class LoadTestGameResult {
|
||||||
int index;
|
int index;
|
||||||
String name;
|
String name;
|
||||||
long randomSeed;
|
long randomSeed;
|
||||||
|
@ -754,12 +763,12 @@ public class LoadTest {
|
||||||
return this.finalGameView.getTurn();
|
return this.finalGameView.getTurn();
|
||||||
}
|
}
|
||||||
|
|
||||||
public int getDuration() {
|
public int getDurationMs() {
|
||||||
return (int) ((this.timeEnded.getTime() - this.timeStarted.getTime()) / 1000);
|
return (int) ((this.timeEnded.getTime() - this.timeStarted.getTime()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private class LoadTestGameResultsList extends HashMap<Integer, LoadTestGameResult> {
|
private static class LoadTestGameResultsList extends HashMap<Integer, LoadTestGameResult> {
|
||||||
|
|
||||||
private static final String tableFormatHeader = "|%-10s|%-15s|%-20s|%-10s|%-15s|%-15s|%-10s|%-20s|%n";
|
private static final String tableFormatHeader = "|%-10s|%-15s|%-20s|%-10s|%-15s|%-15s|%-10s|%-20s|%n";
|
||||||
private static final String tableFormatData = "|%-10s|%15s|%20s|%10s|%15s|%15s|%10s|%20s|%n";
|
private static final String tableFormatData = "|%-10s|%15s|%20s|%10s|%15s|%15s|%10s|%20s|%n";
|
||||||
|
@ -799,8 +808,8 @@ public class LoadTest {
|
||||||
String.valueOf(gameResult.getTurn()), //"turn",
|
String.valueOf(gameResult.getTurn()), //"turn",
|
||||||
String.valueOf(gameResult.getLife1()), //"player 1",
|
String.valueOf(gameResult.getLife1()), //"player 1",
|
||||||
String.valueOf(gameResult.getLife2()), //"player 2",
|
String.valueOf(gameResult.getLife2()), //"player 2",
|
||||||
String.valueOf(gameResult.getDuration()),// "time, sec",
|
String.format("%.3f", (float) gameResult.getDurationMs() / 1000), //"time, sec",
|
||||||
String.valueOf(gameResult.getDuration() / gameResult.getTurn()) //"per turn, sec"
|
String.format("%.3f", ((float) gameResult.getDurationMs() / 1000) / gameResult.getTurn()) //"per turn, sec"
|
||||||
);
|
);
|
||||||
System.out.printf(tableFormatData, data.toArray());
|
System.out.printf(tableFormatData, data.toArray());
|
||||||
}
|
}
|
||||||
|
@ -813,8 +822,8 @@ public class LoadTest {
|
||||||
String.valueOf(this.getAvgTurn()), // turn
|
String.valueOf(this.getAvgTurn()), // turn
|
||||||
String.valueOf(this.getAvgLife1()), // player 1
|
String.valueOf(this.getAvgLife1()), // player 1
|
||||||
String.valueOf(this.getAvgLife2()), // player 2
|
String.valueOf(this.getAvgLife2()), // player 2
|
||||||
String.valueOf(this.getAvgDuration()), // time, sec
|
String.valueOf(String.format("%.3f", (float) this.getAvgDurationMs() / 1000)), // time, sec
|
||||||
String.valueOf(this.getAvgDurationPerTurn()) // time per turn, sec
|
String.valueOf(String.format("%.3f", (float) this.getAvgDurationPerTurnMs() / 1000)) // time per turn, sec
|
||||||
);
|
);
|
||||||
System.out.printf(tableFormatData, data.toArray());
|
System.out.printf(tableFormatData, data.toArray());
|
||||||
}
|
}
|
||||||
|
@ -831,12 +840,12 @@ public class LoadTest {
|
||||||
return this.values().stream().mapToInt(LoadTestGameResult::getLife2).sum() / this.size();
|
return this.values().stream().mapToInt(LoadTestGameResult::getLife2).sum() / this.size();
|
||||||
}
|
}
|
||||||
|
|
||||||
private int getAvgDuration() {
|
private int getAvgDurationMs() {
|
||||||
return this.values().stream().mapToInt(LoadTestGameResult::getDuration).sum() / this.size();
|
return this.values().stream().mapToInt(LoadTestGameResult::getDurationMs).sum() / this.size();
|
||||||
}
|
}
|
||||||
|
|
||||||
private int getAvgDurationPerTurn() {
|
private int getAvgDurationPerTurnMs() {
|
||||||
return getAvgDuration() / getAvgTurn();
|
return getAvgDurationMs() / getAvgTurn();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -849,4 +858,38 @@ public class LoadTest {
|
||||||
Assert.assertNotNull("Can't find game type on the server: " + TEST_AI_GAME_MODE, gameType);
|
Assert.assertNotNull("Can't find game type on the server: " + TEST_AI_GAME_MODE, gameType);
|
||||||
return gameType;
|
return gameType;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private DeckCardLists loadGameDeck(int playerNumber, String deckColors, boolean onlyBasicLands, String allowedSets) {
|
||||||
|
// priority for custom deck file
|
||||||
|
DeckCardLists deckList = null;
|
||||||
|
switch (playerNumber) {
|
||||||
|
case 1:
|
||||||
|
if (!TEST_AI_CUSTOM_DECK_PATH_1.isEmpty()) {
|
||||||
|
deckList = DeckImporter.importDeckFromFile(TEST_AI_CUSTOM_DECK_PATH_1, false);
|
||||||
|
Assert.assertFalse("Can't load custom deck 1 from " + TEST_AI_CUSTOM_DECK_PATH_1, deckList.getCards().isEmpty());
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
if (!TEST_AI_CUSTOM_DECK_PATH_2.isEmpty()) {
|
||||||
|
deckList = DeckImporter.importDeckFromFile(TEST_AI_CUSTOM_DECK_PATH_2, false);
|
||||||
|
Assert.assertFalse("Can't load custom deck 2 from " + TEST_AI_CUSTOM_DECK_PATH_2, deckList.getCards().isEmpty());
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
throw new IllegalArgumentException("Unsupported player number " + playerNumber);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (deckList == null) {
|
||||||
|
deckList = DeckTestUtils.buildRandomDeckAndInitCards(deckColors, onlyBasicLands, allowedSets);
|
||||||
|
}
|
||||||
|
|
||||||
|
return deckList;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void printGameResults(LoadTestGameResultsList gameResults) {
|
||||||
|
System.out.println();
|
||||||
|
gameResults.printResultHeader();
|
||||||
|
gameResults.printResultData();
|
||||||
|
gameResults.printResultTotal();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,9 +23,9 @@ public class SimpleMageClient implements MageClient {
|
||||||
|
|
||||||
private final LoadCallbackClient callbackClient;
|
private final LoadCallbackClient callbackClient;
|
||||||
|
|
||||||
public SimpleMageClient(boolean joinGameChat) {
|
public SimpleMageClient(boolean joinGameChat, String logsPrefix) {
|
||||||
clientId = UUID.randomUUID();
|
clientId = UUID.randomUUID();
|
||||||
callbackClient = new LoadCallbackClient(joinGameChat);
|
callbackClient = new LoadCallbackClient(joinGameChat, logsPrefix);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
Loading…
Reference in a new issue