summaryrefslogtreecommitdiff
path: root/backend/src
diff options
context:
space:
mode:
Diffstat (limited to 'backend/src')
-rw-r--r--backend/src/test/java/org/luxons/sevenwonders/SevenWondersTest.java83
1 files changed, 74 insertions, 9 deletions
diff --git a/backend/src/test/java/org/luxons/sevenwonders/SevenWondersTest.java b/backend/src/test/java/org/luxons/sevenwonders/SevenWondersTest.java
index e2e2f84f..d6415376 100644
--- a/backend/src/test/java/org/luxons/sevenwonders/SevenWondersTest.java
+++ b/backend/src/test/java/org/luxons/sevenwonders/SevenWondersTest.java
@@ -1,18 +1,27 @@
package org.luxons.sevenwonders;
+import java.util.concurrent.ExecutionException;
+import java.util.concurrent.TimeoutException;
+
import org.junit.After;
import org.junit.Before;
import org.junit.BeforeClass;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.luxons.sevenwonders.test.api.ApiLobby;
+import org.luxons.sevenwonders.test.api.ApiPlayer;
+import org.luxons.sevenwonders.test.api.ApiPlayerTurnInfo;
import org.luxons.sevenwonders.test.api.SevenWondersClient;
import org.luxons.sevenwonders.test.api.SevenWondersSession;
+import org.luxons.sevenwonders.test.client.Channel;
import org.springframework.boot.context.embedded.LocalServerPort;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.boot.test.context.SpringBootTest.WebEnvironment;
import org.springframework.test.context.junit4.SpringRunner;
+import static org.junit.Assert.assertEquals;
+import static org.junit.Assert.assertNotNull;
+
@RunWith(SpringRunner.class)
@SpringBootTest(webEnvironment = WebEnvironment.RANDOM_PORT)
public class SevenWondersTest {
@@ -43,28 +52,84 @@ public class SevenWondersTest {
}
@Test
- public void testConnection() throws Exception {
+ public void chooseName() throws InterruptedException, ExecutionException, TimeoutException {
SevenWondersSession session = client.connect(serverUrl);
- session.chooseName("Test User");
+ String playerName = "Test User";
+ ApiPlayer player = session.chooseName(playerName);
+ assertNotNull(player);
+ assertEquals(playerName, player.getDisplayName());
session.disconnect();
}
@Test
- public void testConnection_2users() throws Exception {
- SevenWondersSession session1 = client.connect(serverUrl);
- SevenWondersSession session2 = client.connect(serverUrl);
- session1.chooseName("Player1");
- session2.chooseName( "Player2");
+ public void createGame_success() throws InterruptedException, ExecutionException, TimeoutException {
+ SevenWondersSession ownerSession = client.connect(serverUrl);
+ ownerSession.chooseName("GameOwner");
+
+ String gameName = "Test Game";
+ ApiLobby lobby = ownerSession.createGame(gameName);
+ assertNotNull(lobby);
+ assertEquals(gameName, lobby.getName());
+
+ disconnect(ownerSession);
+ }
+
+ private SevenWondersSession newPlayer(String name) throws InterruptedException, TimeoutException,
+ ExecutionException {
+ SevenWondersSession otherSession = client.connect(serverUrl);
+ otherSession.chooseName(name);
+ return otherSession;
+ }
+
+ @Test
+ public void createGame_seenByConnectedPlayers() throws InterruptedException, ExecutionException, TimeoutException {
+ SevenWondersSession otherSession = newPlayer("OtherPlayer");
+ Channel<ApiLobby[]> games = otherSession.watchGames();
+
+ ApiLobby[] receivedLobbies = games.next();
+ assertNotNull(receivedLobbies);
+ assertEquals(0, receivedLobbies.length);
+
+ SevenWondersSession ownerSession = newPlayer("GameOwner");
+ String gameName = "Test Game";
+ ApiLobby createdLobby = ownerSession.createGame(gameName);
+
+ receivedLobbies = games.next();
+ assertNotNull(receivedLobbies);
+ assertEquals(1, receivedLobbies.length);
+ ApiLobby receivedLobby = receivedLobbies[0];
+ assertEquals(createdLobby.getId(), receivedLobby.getId());
+ assertEquals(createdLobby.getName(), receivedLobby.getName());
+
+ disconnect(ownerSession, otherSession);
+ }
+
+ @Test
+ public void startGame_3players() throws Exception {
+ SevenWondersSession session1 = newPlayer("Player1");
+ SevenWondersSession session2 = newPlayer( "Player2");
ApiLobby lobby = session1.createGame("Test Game");
session2.joinGame(lobby.getId());
- SevenWondersSession session3 = client.connect(serverUrl);
- session3.chooseName("Player3");
+ SevenWondersSession session3 = newPlayer("Player3");
session3.joinGame(lobby.getId());
session1.startGame(lobby.getId());
+ Channel<ApiPlayerTurnInfo> turns1 = session1.watchTurns();
+ Channel<ApiPlayerTurnInfo> turns2 = session2.watchTurns();
+ Channel<ApiPlayerTurnInfo> turns3 = session3.watchTurns();
+ session1.sayReady();
+ session2.sayReady();
+ session3.sayReady();
+ ApiPlayerTurnInfo turn1 = turns1.next();
+ ApiPlayerTurnInfo turn2 = turns2.next();
+ ApiPlayerTurnInfo turn3 = turns3.next();
+ assertNotNull(turn1);
+ assertNotNull(turn2);
+ assertNotNull(turn3);
+
disconnect(session1, session2, session3);
}
bgstack15