From 8877f1476f826cf5f4b11b6aefeeeb9b354b4524 Mon Sep 17 00:00:00 2001 From: Andrin Fassbind Date: Tue, 22 Mar 2022 18:47:14 +0100 Subject: [PATCH] GameTest --- .../java/ch/zhaw/pm2/racetrack/GameTest.java | 129 ++++++++++++++++-- 1 file changed, 114 insertions(+), 15 deletions(-) diff --git a/src/test/java/ch/zhaw/pm2/racetrack/GameTest.java b/src/test/java/ch/zhaw/pm2/racetrack/GameTest.java index 03cb0f3..ebfb473 100644 --- a/src/test/java/ch/zhaw/pm2/racetrack/GameTest.java +++ b/src/test/java/ch/zhaw/pm2/racetrack/GameTest.java @@ -1,11 +1,14 @@ package ch.zhaw.pm2.racetrack; import ch.zhaw.pm2.racetrack.strategy.UserMoveStrategy; +import org.junit.Before; import org.junit.jupiter.api.*; import java.io.File; +import java.util.List; import static ch.zhaw.pm2.racetrack.Game.NO_WINNER; +import static ch.zhaw.pm2.racetrack.PositionVector.Direction.*; class GameTest { private UserInterface userInterface; @@ -20,40 +23,40 @@ class GameTest { userInterface = new UserInterface("Test"); game = new Game(userInterface); track = game.selectTrack(new File(".\\tracks\\challenge.txt")); - game.selectMoveStrategy(track.getCar(0),new UserMoveStrategy(new UserInterface("Testing"),0, track.getCarId(0))); - game.selectMoveStrategy(track.getCar(1),new UserMoveStrategy(new UserInterface("Testing"),1, track.getCarId(1))); + game.selectMoveStrategy(track.getCar(0), new UserMoveStrategy(new UserInterface("Testing"), 0, track.getCarId(0))); + game.selectMoveStrategy(track.getCar(1), new UserMoveStrategy(new UserInterface("Testing"), 1, track.getCarId(1))); } @Test void getCurrentCarIndex() { - Assertions.assertEquals(0,game.getCurrentCarIndex()); + Assertions.assertEquals(0, game.getCurrentCarIndex()); game.switchToNextActiveCar(); - Assertions.assertEquals(1,game.getCurrentCarIndex()); + Assertions.assertEquals(1, game.getCurrentCarIndex()); } @Test void getCarId() { - Assertions.assertEquals('a',game.getCarId(0)); - Assertions.assertEquals('b',game.getCarId(1)); + Assertions.assertEquals('a', game.getCarId(0)); + Assertions.assertEquals('b', game.getCarId(1)); } @Test void getCarPosition() { - Assertions.assertEquals(new PositionVector(24,22),game.getCarPosition(0)); - Assertions.assertEquals(new PositionVector(24,24),game.getCarPosition(1)); + Assertions.assertEquals(new PositionVector(24, 22), game.getCarPosition(0)); + Assertions.assertEquals(new PositionVector(24, 24), game.getCarPosition(1)); } @Test void getCarVelocity() { - Assertions.assertEquals(new PositionVector(0,0),game.getCarVelocity(0)); - Assertions.assertEquals(new PositionVector(0,0),game.getCarVelocity(1)); + Assertions.assertEquals(new PositionVector(0, 0), game.getCarVelocity(0)); + Assertions.assertEquals(new PositionVector(0, 0), game.getCarVelocity(1)); } @Test void getWinner() { - Assertions.assertEquals(NO_WINNER,game.getWinner()); + Assertions.assertEquals(NO_WINNER, game.getWinner()); } @Test @@ -75,16 +78,16 @@ class GameTest { userInterface = new UserInterface("Test"); game = new Game(userInterface); track = game.selectTrack(new File(".\\tracks\\challenge.txt")); - game.selectMoveStrategy(track.getCar(0),new UserMoveStrategy(new UserInterface("Testing"),0, track.getCarId(0))); - game.selectMoveStrategy(track.getCar(1),new UserMoveStrategy(new UserInterface("Testing"),1, track.getCarId(1))); + game.selectMoveStrategy(track.getCar(0), new UserMoveStrategy(new UserInterface("Testing"), 0, track.getCarId(0))); + game.selectMoveStrategy(track.getCar(1), new UserMoveStrategy(new UserInterface("Testing"), 1, track.getCarId(1))); } @Test void carTurnCorrect() { try { - game.doCarTurn(PositionVector.Direction.RIGHT); - Assertions.assertEquals(new PositionVector(1,0),game.getCarVelocity(0)); + game.doCarTurn(RIGHT); + Assertions.assertEquals(new PositionVector(1, 0), game.getCarVelocity(0)); } catch (PositionVectorNotValid positionVectorNotValid) { positionVectorNotValid.printStackTrace(); } @@ -99,6 +102,102 @@ class GameTest { positionVectorNotValid.printStackTrace(); } } + } + + @Nested + @DisplayName("Playtrough") + class Play { + private Game game; + + @Test + void winner() { + game = new Game(new interFace("Test")); + try { + game.initPhase(); + Assertions.assertEquals('a',game.gamePhase()); + } catch (InvalidTrackFormatException | PositionVectorNotValid e) { + e.printStackTrace(); + } + } + + + + } + + private class interFace extends UserInterface { + + private static PositionVector.Direction[] directions = {RIGHT, + RIGHT, + RIGHT, + NONE, + NONE, + NONE, + NONE, + UP, + LEFT, + LEFT, + LEFT, + LEFT, + UP_LEFT, + NONE, + RIGHT, + RIGHT, + RIGHT, + NONE, + LEFT, + DOWN_LEFT, + DOWN_LEFT, + LEFT, + LEFT, + NONE, + RIGHT, + NONE, + DOWN, + DOWN, + RIGHT, + NONE, + RIGHT, + DOWN, + NONE, + UP_RIGHT, + RIGHT, + UP_RIGHT, + UP_RIGHT, + RIGHT, + RIGHT}; + + private static int pointer = -1; + + public interFace(String welcometxt) { + super(welcometxt); + } + + @Override + public int selectOption(String text, List options) { + if (text.equals("Select Track file")) { + return 1; + } else if (text.contains("Select Strategy for Car")) { + return 2; + } + return 0; + } + + public void printInformation(String text) { + } + + public void printTrack(Track track) { + } + + public void quit(String text) { + } + + public PositionVector.Direction selectDirection(int playingCarIndex, char playingCarID) { + pointer += 1; + if(pointer < directions.length) { + return directions[pointer]; + } + return NONE; + } } }