3 Commits

Author SHA1 Message Date
22bf1361ee WIP : add TIE result 2025-11-27 12:33:05 +01:00
a9de7a9448 fix: RandomCpuPickerTest add assert for well 2025-11-27 10:24:28 +01:00
216cb51c0d feature: add well 2025-11-27 10:14:59 +01:00
7 changed files with 48 additions and 13 deletions

View File

@@ -0,0 +1,7 @@
package fr.iut_fbleau.info.but3.automation.rock_paper_scissors.play.domain;
public enum GameResult {
WIN,
LOOSE,
TIE,
}

View File

@@ -3,13 +3,18 @@ package fr.iut_fbleau.info.but3.automation.rock_paper_scissors.play.domain;
public enum Move { public enum Move {
ROCK, ROCK,
PAPER, PAPER,
SCISSORS; SCISSORS,
WELL;
public boolean beats(Move other) { public GameResult beats(Move other) {
return switch (this) { if (this.equals(other))
return GameResult.TIE;
boolean beats = switch (this) {
case ROCK -> other == SCISSORS; case ROCK -> other == SCISSORS;
case PAPER -> other == ROCK; case PAPER -> other == ROCK || other == WELL;
case SCISSORS -> other == PAPER; case SCISSORS -> other == PAPER;
case WELL -> other == ROCK || other == SCISSORS;
}; };
return beats ? GameResult.WIN : GameResult.LOOSE;
} }
} }

View File

@@ -11,12 +11,14 @@ 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();
boolean beats = move.beats(cpuPicked); GameResult beats = move.beats(cpuPicked);
String result = beats ? WIN : LOOSE; String result = String.valueOf(beats);
if (result.equals(WIN)) { if (result.equals(WIN)) {
this.statSave.addWin(name); this.statSave.addWin(name);
} }

View File

@@ -24,8 +24,7 @@ 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.LOOSE; 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.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;
@@ -46,7 +45,8 @@ 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,5 +67,4 @@ 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()));
} }
} }

View File

@@ -4,6 +4,7 @@ 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;
@@ -14,9 +15,12 @@ class MoveTest {
@Test @Test
void should_check_move_size(){ void should_check_move_size(){
Assertions.assertEquals(3, 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) {
@@ -29,11 +33,20 @@ 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),
Arguments.of(Move.PAPER,Move.ROCK), Arguments.of(Move.PAPER,Move.ROCK),
Arguments.of(Move.SCISSORS,Move.PAPER) Arguments.of(Move.PAPER,Move.WELL),
Arguments.of(Move.SCISSORS,Move.PAPER),
Arguments.of(Move.WELL,Move.ROCK),
Arguments.of(Move.WELL,Move.SCISSORS)
); );
} }
} }

View File

@@ -39,4 +39,12 @@ 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());
}
} }

View File

@@ -20,9 +20,10 @@ class RandomCpuPickerTest {
obtainedMoves.add(picker.pick()); obtainedMoves.add(picker.pick());
} }
assertEquals(3, obtainedMoves.size()); assertEquals(4, obtainedMoves.size());
assertTrue(obtainedMoves.contains(Move.ROCK)); assertTrue(obtainedMoves.contains(Move.ROCK));
assertTrue(obtainedMoves.contains(Move.PAPER)); assertTrue(obtainedMoves.contains(Move.PAPER));
assertTrue(obtainedMoves.contains(Move.SCISSORS)); assertTrue(obtainedMoves.contains(Move.SCISSORS));
assertTrue(obtainedMoves.contains(Move.WELL));
} }
} }