forked from pierront/rock-paper-scissors
Compare commits
1 Commits
feature/ad
...
main
| Author | SHA1 | Date | |
|---|---|---|---|
| bfb5985d9a |
@@ -1,7 +0,0 @@
|
|||||||
package fr.iut_fbleau.info.but3.automation.rock_paper_scissors.play.domain;
|
|
||||||
|
|
||||||
public enum GameResult {
|
|
||||||
WIN,
|
|
||||||
LOOSE,
|
|
||||||
TIE,
|
|
||||||
}
|
|
||||||
@@ -6,15 +6,12 @@ public enum Move {
|
|||||||
SCISSORS,
|
SCISSORS,
|
||||||
WELL;
|
WELL;
|
||||||
|
|
||||||
public GameResult beats(Move other) {
|
public boolean beats(Move other) {
|
||||||
if (this.equals(other))
|
return switch (this) {
|
||||||
return GameResult.TIE;
|
|
||||||
boolean beats = switch (this) {
|
|
||||||
case ROCK -> other == SCISSORS;
|
case ROCK -> other == SCISSORS;
|
||||||
case PAPER -> other == ROCK || other == WELL;
|
case PAPER -> other == ROCK || other == WELL;
|
||||||
case SCISSORS -> other == PAPER;
|
case SCISSORS -> other == PAPER;
|
||||||
case WELL -> other == ROCK || other == SCISSORS;
|
case WELL -> other == ROCK || other == SCISSORS;
|
||||||
};
|
};
|
||||||
return beats ? GameResult.WIN : GameResult.LOOSE;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -11,14 +11,12 @@ public record RockPaperScissorsPlayer(CpuPick cpuPick, StatSave statSave) implem
|
|||||||
|
|
||||||
public static final String WIN = "WIN";
|
public static final String WIN = "WIN";
|
||||||
public static final String LOOSE = "LOOSE";
|
public static final String LOOSE = "LOOSE";
|
||||||
public static final String TIE = "TIE";
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public RoundResult playRound(String name, Move move) {
|
public RoundResult playRound(String name, Move move) {
|
||||||
var cpuPicked = this.cpuPick.pick();
|
var cpuPicked = this.cpuPick.pick();
|
||||||
GameResult beats = move.beats(cpuPicked);
|
boolean beats = move.beats(cpuPicked);
|
||||||
String result = String.valueOf(beats);
|
String result = beats ? WIN : LOOSE;
|
||||||
|
|
||||||
if (result.equals(WIN)) {
|
if (result.equals(WIN)) {
|
||||||
this.statSave.addWin(name);
|
this.statSave.addWin(name);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -24,7 +24,8 @@ import org.springframework.test.web.servlet.MockMvc;
|
|||||||
|
|
||||||
import java.util.stream.Stream;
|
import java.util.stream.Stream;
|
||||||
|
|
||||||
import static fr.iut_fbleau.info.but3.automation.rock_paper_scissors.play.domain.RockPaperScissorsPlayer.*;
|
import static fr.iut_fbleau.info.but3.automation.rock_paper_scissors.play.domain.RockPaperScissorsPlayer.LOOSE;
|
||||||
|
import static fr.iut_fbleau.info.but3.automation.rock_paper_scissors.play.domain.RockPaperScissorsPlayer.WIN;
|
||||||
import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.post;
|
import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.post;
|
||||||
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.jsonPath;
|
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.jsonPath;
|
||||||
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status;
|
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status;
|
||||||
@@ -45,8 +46,7 @@ public class PlayControllerTest {
|
|||||||
public static Stream<Arguments> scenario() {
|
public static Stream<Arguments> scenario() {
|
||||||
return Stream.of(
|
return Stream.of(
|
||||||
Arguments.of(Move.ROCK, Move.SCISSORS, WIN),
|
Arguments.of(Move.ROCK, Move.SCISSORS, WIN),
|
||||||
Arguments.of(Move.ROCK, Move.PAPER, LOOSE),
|
Arguments.of(Move.ROCK, Move.PAPER, LOOSE)
|
||||||
Arguments.of(Move.ROCK,Move.ROCK, TIE)
|
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -67,4 +67,5 @@ public class PlayControllerTest {
|
|||||||
.andExpect(jsonPath("$.result").value(expectedResult))
|
.andExpect(jsonPath("$.result").value(expectedResult))
|
||||||
.andExpect(jsonPath("$.cpu").value(cpuMove.name()));
|
.andExpect(jsonPath("$.cpu").value(cpuMove.name()));
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -4,7 +4,6 @@ import org.junit.jupiter.api.Assertions;
|
|||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
import org.junit.jupiter.params.ParameterizedTest;
|
import org.junit.jupiter.params.ParameterizedTest;
|
||||||
import org.junit.jupiter.params.provider.Arguments;
|
import org.junit.jupiter.params.provider.Arguments;
|
||||||
import org.junit.jupiter.params.provider.EnumSource;
|
|
||||||
import org.junit.jupiter.params.provider.MethodSource;
|
import org.junit.jupiter.params.provider.MethodSource;
|
||||||
|
|
||||||
import java.util.stream.Stream;
|
import java.util.stream.Stream;
|
||||||
@@ -18,9 +17,6 @@ class MoveTest {
|
|||||||
Assertions.assertEquals(4, Move.values().length);
|
Assertions.assertEquals(4, Move.values().length);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void assertTrue(GameResult beats) {}
|
|
||||||
private void assertFalse(GameResult beats) {}
|
|
||||||
|
|
||||||
@ParameterizedTest(name = "{0} should beat {1}")
|
@ParameterizedTest(name = "{0} should beat {1}")
|
||||||
@MethodSource("winnable")
|
@MethodSource("winnable")
|
||||||
void should_win(Move move1, Move move2) {
|
void should_win(Move move1, Move move2) {
|
||||||
@@ -33,12 +29,6 @@ class MoveTest {
|
|||||||
assertFalse(move2.beats(move1));
|
assertFalse(move2.beats(move1));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ParameterizedTest(name = "{1} should tie against {0}")
|
|
||||||
@EnumSource(Move.class)
|
|
||||||
void should_tie(Move move) {
|
|
||||||
assertFalse(move.beats(move));
|
|
||||||
}
|
|
||||||
|
|
||||||
static Stream<Arguments> winnable(){
|
static Stream<Arguments> winnable(){
|
||||||
return Stream.of(
|
return Stream.of(
|
||||||
Arguments.of(Move.ROCK,Move.SCISSORS),
|
Arguments.of(Move.ROCK,Move.SCISSORS),
|
||||||
|
|||||||
@@ -39,12 +39,4 @@ public class RockPaperScissorsPlayTest {
|
|||||||
assertEquals(Move.ROCK, roundResult.cpuChoice());
|
assertEquals(Move.ROCK, roundResult.cpuChoice());
|
||||||
verify(statSaver, times(0)).addWin("joe");
|
verify(statSaver, times(0)).addWin("joe");
|
||||||
}
|
}
|
||||||
|
|
||||||
void should_tie_a_game(){
|
|
||||||
cpuPick.setNextMove(Move.ROCK);
|
|
||||||
RoundResult roundResult = play.playRound("joe", Move.ROCK);
|
|
||||||
assertEquals("TIE", roundResult.result());
|
|
||||||
assertEquals("joe", roundResult.opponent());
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user