Compare commits
11 Commits
add-ci
...
feature/ad
| Author | SHA1 | Date | |
|---|---|---|---|
| 22bf1361ee | |||
| a9de7a9448 | |||
| 216cb51c0d | |||
| 9b1af5029f | |||
|
|
9865e9dcc2 | ||
|
|
ca34df2af9 | ||
| b451ad2233 | |||
| 8bf1594329 | |||
| b8c9b382d8 | |||
| 56206c02bb | |||
| 9405b66593 |
@@ -0,0 +1,7 @@
|
||||
package fr.iut_fbleau.info.but3.automation.rock_paper_scissors.play.domain;
|
||||
|
||||
public enum GameResult {
|
||||
WIN,
|
||||
LOOSE,
|
||||
TIE,
|
||||
}
|
||||
@@ -3,13 +3,18 @@ package fr.iut_fbleau.info.but3.automation.rock_paper_scissors.play.domain;
|
||||
public enum Move {
|
||||
ROCK,
|
||||
PAPER,
|
||||
SCISSORS;
|
||||
SCISSORS,
|
||||
WELL;
|
||||
|
||||
public boolean beats(Move other) {
|
||||
return switch (this) {
|
||||
public GameResult beats(Move other) {
|
||||
if (this.equals(other))
|
||||
return GameResult.TIE;
|
||||
boolean beats = switch (this) {
|
||||
case ROCK -> other == SCISSORS;
|
||||
case PAPER -> other == ROCK;
|
||||
case PAPER -> other == ROCK || other == WELL;
|
||||
case SCISSORS -> other == PAPER;
|
||||
case WELL -> other == ROCK || other == SCISSORS;
|
||||
};
|
||||
return beats ? GameResult.WIN : GameResult.LOOSE;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -11,12 +11,14 @@ public record RockPaperScissorsPlayer(CpuPick cpuPick, StatSave statSave) implem
|
||||
|
||||
public static final String WIN = "WIN";
|
||||
public static final String LOOSE = "LOOSE";
|
||||
public static final String TIE = "TIE";
|
||||
|
||||
@Override
|
||||
public RoundResult playRound(String name, Move move) {
|
||||
var cpuPicked = this.cpuPick.pick();
|
||||
boolean beats = move.beats(cpuPicked);
|
||||
String result = beats ? WIN : LOOSE;
|
||||
GameResult beats = move.beats(cpuPicked);
|
||||
String result = String.valueOf(beats);
|
||||
|
||||
if (result.equals(WIN)) {
|
||||
this.statSave.addWin(name);
|
||||
}
|
||||
|
||||
@@ -2,6 +2,7 @@ package fr.iut_fbleau.info.but3.automation.rock_paper_scissors.stat.web;
|
||||
|
||||
import fr.iut_fbleau.info.but3.automation.rock_paper_scissors.stat.domain.StatBoard;
|
||||
|
||||
import java.util.Comparator;
|
||||
import java.util.List;
|
||||
|
||||
public record StatBoardReponse(List<Stat> stats) {
|
||||
@@ -9,6 +10,8 @@ public record StatBoardReponse(List<Stat> stats) {
|
||||
public StatBoardReponse(StatBoard statBoard) {
|
||||
this(statBoard.stats().entrySet().stream()
|
||||
.map(Stat::fromMap)
|
||||
.sorted(Comparator.comparingInt(
|
||||
stat -> -stat.wins()))
|
||||
.toList());
|
||||
}
|
||||
}
|
||||
|
||||
@@ -3,7 +3,7 @@ package fr.iut_fbleau.info.but3.automation.rock_paper_scissors;
|
||||
import org.junit.jupiter.api.Test;
|
||||
import org.springframework.modulith.core.ApplicationModules;
|
||||
|
||||
public class ModulithStructureTests {
|
||||
class ModulithStructureTests {
|
||||
|
||||
@Test
|
||||
void verifyModularStructure() {
|
||||
|
||||
@@ -24,8 +24,7 @@ import org.springframework.test.web.servlet.MockMvc;
|
||||
|
||||
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.WIN;
|
||||
import static fr.iut_fbleau.info.but3.automation.rock_paper_scissors.play.domain.RockPaperScissorsPlayer.*;
|
||||
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.status;
|
||||
@@ -46,7 +45,8 @@ public class PlayControllerTest {
|
||||
public static Stream<Arguments> scenario() {
|
||||
return Stream.of(
|
||||
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("$.cpu").value(cpuMove.name()));
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@@ -26,7 +26,7 @@ import static org.springframework.boot.test.context.SpringBootTest.WebEnvironmen
|
||||
webEnvironment = RANDOM_PORT
|
||||
)
|
||||
@Import(FakeCpuConfiguration.class)
|
||||
public class RockPaperScissorsPlayApplicationTest {
|
||||
class RockPaperScissorsPlayApplicationTest {
|
||||
|
||||
@Autowired
|
||||
private TestRestTemplate restTemplate;
|
||||
|
||||
@@ -4,19 +4,23 @@ import org.junit.jupiter.api.Assertions;
|
||||
import org.junit.jupiter.api.Test;
|
||||
import org.junit.jupiter.params.ParameterizedTest;
|
||||
import org.junit.jupiter.params.provider.Arguments;
|
||||
import org.junit.jupiter.params.provider.EnumSource;
|
||||
import org.junit.jupiter.params.provider.MethodSource;
|
||||
|
||||
import java.util.stream.Stream;
|
||||
|
||||
import static org.junit.jupiter.api.Assertions.*;
|
||||
|
||||
public class MoveTest {
|
||||
class MoveTest {
|
||||
|
||||
@Test
|
||||
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}")
|
||||
@MethodSource("winnable")
|
||||
void should_win(Move move1, Move move2) {
|
||||
@@ -29,11 +33,20 @@ public class MoveTest {
|
||||
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(){
|
||||
return Stream.of(
|
||||
Arguments.of(Move.ROCK,Move.SCISSORS),
|
||||
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)
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,17 +1,16 @@
|
||||
package fr.iut_fbleau.info.but3.automation.rock_paper_scissors.play.domain;
|
||||
|
||||
import static org.junit.jupiter.api.Assertions.assertEquals;
|
||||
import static org.mockito.Mockito.mock;
|
||||
import static org.mockito.Mockito.times;
|
||||
import static org.mockito.Mockito.verify;
|
||||
|
||||
import fr.iut_fbleau.info.but3.automation.rock_paper_scissors.play.RockPaperScissorsPlay;
|
||||
import fr.iut_fbleau.info.but3.automation.rock_paper_scissors.play.spi.FakeCpuPicker;
|
||||
import fr.iut_fbleau.info.but3.automation.rock_paper_scissors.stat.domain.StatSaver;
|
||||
import fr.iut_fbleau.info.but3.automation.rock_paper_scissors.stat.spi.stub.InMemoryStatRepository;
|
||||
import org.junit.jupiter.api.Test;
|
||||
import org.junit.jupiter.api.extension.ExtendWith;
|
||||
import org.mockito.Mock;
|
||||
import org.mockito.junit.jupiter.MockitoExtension;
|
||||
import org.springframework.test.context.bean.override.mockito.MockitoBean;
|
||||
|
||||
import static org.junit.jupiter.api.Assertions.assertEquals;
|
||||
import static org.mockito.Mockito.*;
|
||||
|
||||
@ExtendWith(MockitoExtension.class)
|
||||
public class RockPaperScissorsPlayTest {
|
||||
@@ -40,4 +39,12 @@ public class RockPaperScissorsPlayTest {
|
||||
assertEquals(Move.ROCK, roundResult.cpuChoice());
|
||||
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());
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@@ -20,9 +20,10 @@ class RandomCpuPickerTest {
|
||||
obtainedMoves.add(picker.pick());
|
||||
}
|
||||
|
||||
assertEquals(3, obtainedMoves.size());
|
||||
assertEquals(4, obtainedMoves.size());
|
||||
assertTrue(obtainedMoves.contains(Move.ROCK));
|
||||
assertTrue(obtainedMoves.contains(Move.PAPER));
|
||||
assertTrue(obtainedMoves.contains(Move.SCISSORS));
|
||||
assertTrue(obtainedMoves.contains(Move.WELL));
|
||||
}
|
||||
}
|
||||
@@ -14,7 +14,7 @@ import static org.springframework.boot.test.context.SpringBootTest.WebEnvironmen
|
||||
@ApplicationModuleTest(
|
||||
webEnvironment = RANDOM_PORT
|
||||
)
|
||||
public class StatApplicationTest {
|
||||
class StatApplicationTest {
|
||||
@Autowired
|
||||
private TestRestTemplate restTemplate;
|
||||
|
||||
@@ -27,9 +27,9 @@ public class StatApplicationTest {
|
||||
assertThat(response.getStatusCode()).isEqualTo(HttpStatus.OK);
|
||||
|
||||
assertThat(json.from(response.getBody())).extractingJsonPathArrayValue("@.stats").hasSize(2);
|
||||
assertThat(json.from(response.getBody())).extractingJsonPathStringValue("@.stats[0].name").isEqualTo("joe");
|
||||
assertThat(json.from(response.getBody())).extractingJsonPathNumberValue("@.stats[0].wins").isEqualTo(1);
|
||||
assertThat(json.from(response.getBody())).extractingJsonPathStringValue("@.stats[1].name").isEqualTo("eoj");
|
||||
assertThat(json.from(response.getBody())).extractingJsonPathNumberValue("@.stats[1].wins").isEqualTo(3);
|
||||
assertThat(json.from(response.getBody())).extractingJsonPathStringValue("@.stats[0].name").isEqualTo("eoj");
|
||||
assertThat(json.from(response.getBody())).extractingJsonPathNumberValue("@.stats[0].wins").isEqualTo(3);
|
||||
assertThat(json.from(response.getBody())).extractingJsonPathStringValue("@.stats[1].name").isEqualTo("joe");
|
||||
assertThat(json.from(response.getBody())).extractingJsonPathNumberValue("@.stats[1].wins").isEqualTo(1);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -3,6 +3,7 @@ package fr.iut_fbleau.info.but3.automation.rock_paper_scissors.stat;
|
||||
import fr.iut_fbleau.info.but3.automation.rock_paper_scissors.stat.domain.StatBoard;
|
||||
import fr.iut_fbleau.info.but3.automation.rock_paper_scissors.stat.domain.StatBoardGetter;
|
||||
import fr.iut_fbleau.info.but3.automation.rock_paper_scissors.stat.spi.stub.InMemoryStatRepository;
|
||||
import java.util.LinkedHashMap;
|
||||
import org.junit.jupiter.api.Test;
|
||||
|
||||
import java.util.HashMap;
|
||||
@@ -10,12 +11,13 @@ import java.util.HashMap;
|
||||
import static org.junit.jupiter.api.Assertions.assertEquals;
|
||||
import static org.junit.jupiter.api.Assertions.assertNotNull;
|
||||
|
||||
public class StatBoardGetterTest {
|
||||
class StatBoardGetterTest {
|
||||
|
||||
@Test
|
||||
public void should_get_stat_board() {
|
||||
HashMap<String, Integer> stats = new HashMap<>();
|
||||
stats.put("joe", 1);
|
||||
void should_get_stat_board() {
|
||||
HashMap<String, Integer> stats = new LinkedHashMap<>();
|
||||
stats.put("eoj", 5);
|
||||
stats.put("joe", 1);
|
||||
InMemoryStatRepository statRepository = new InMemoryStatRepository(stats);
|
||||
|
||||
StatBoardGet statBoardGet = new StatBoardGetter(statRepository);
|
||||
|
||||
@@ -20,7 +20,7 @@ import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.
|
||||
|
||||
@WebMvcTest(StatController.class)
|
||||
@Import(StatConfiguration.class)
|
||||
public class StatControllerTest {
|
||||
class StatControllerTest {
|
||||
|
||||
private static final String STAT_ENDPOINT = "/stat";
|
||||
|
||||
@@ -36,8 +36,8 @@ public class StatControllerTest {
|
||||
mockMvc.perform(get(STAT_ENDPOINT))
|
||||
.andExpect(status().isOk())
|
||||
.andExpect(jsonPath("$.stats").isArray())
|
||||
.andExpect(jsonPath("$.stats[0].name").value("joe"))
|
||||
.andExpect(jsonPath("$.stats[0].wins").value(1));
|
||||
.andExpect(jsonPath("$.stats[0].name").value("eoj"))
|
||||
.andExpect(jsonPath("$.stats[0].wins").value(3));
|
||||
}
|
||||
|
||||
@TestConfiguration
|
||||
|
||||
@@ -10,7 +10,7 @@ import java.util.Map;
|
||||
|
||||
import static org.junit.jupiter.api.Assertions.assertEquals;
|
||||
|
||||
public class StatSaverTest {
|
||||
class StatSaverTest {
|
||||
@ParameterizedTest(name = "name = {0}, initial = {1}, expected = {2}")
|
||||
@CsvSource({"joe,0,1", "eoj,2,3"})
|
||||
void should_save(String name, int initial, int expected) {
|
||||
|
||||
Reference in New Issue
Block a user