1 Commits

Author SHA1 Message Date
Maxime Pierront
38a31b3e2b Update Jenkins pipeline setup instructions in README. 2025-11-27 09:49:34 +01:00
7 changed files with 24 additions and 52 deletions

View File

@@ -7,6 +7,8 @@ Se rendre sur : https://grond.iut-fbleau.fr/pierront/rock-paper-scissors
Faire un fork Faire un fork
`/!\ ATTENTION NE PRENDRE QUE LA BRANCHE MAIN /!\`
## Créer la VM pour jenkins ## Créer la VM pour jenkins
### Créer la règle pare-feu pour accéder aux ports 8080 et 8081 ### Créer la règle pare-feu pour accéder aux ports 8080 et 8081
Aller dans la section Pare-Feu Aller dans la section Pare-Feu
@@ -117,7 +119,7 @@ Vous devriez voir la page d'accueil de Jenkins
--- ---
## Création d'un pipeline ## Création d'un pipeline
* Aller dans la section Manage Jenkins -> New Item * Aller sur l'accueil Jenkins -> New Item
* Nommer le projet : rock-paper-scissors * Nommer le projet : rock-paper-scissors
* Choisir le type de projet : Multibranch Pipeline * Choisir le type de projet : Multibranch Pipeline
* Cliquer sur OK * Cliquer sur OK
@@ -126,7 +128,6 @@ Vous devriez voir la page d'accueil de Jenkins
* utiliser le jeton gitea-token * utiliser le jeton gitea-token
* owner : _<votre nom d'utilisateur gitea>_ * owner : _<votre nom d'utilisateur gitea>_
* Choisir le projet : rock-paper-scissors * Choisir le projet : rock-paper-scissors
* Choisir le provider : Git
* Choisir le repository : https://grond.iut-fbleau.fr/pierront/rock-paper-scissors.git * Choisir le repository : https://grond.iut-fbleau.fr/pierront/rock-paper-scissors.git
* Cliquer sur Save * Cliquer sur Save

View File

@@ -3,21 +3,13 @@ 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 Result beats(Move other) { public boolean beats(Move other) {
if(this.equals(other)){ return switch (this) {
return Result.EQUAL;
}
boolean result = switch (this) {
case ROCK -> other == SCISSORS; case ROCK -> other == SCISSORS;
case PAPER -> other == ROCK || other == WELL; case PAPER -> other == ROCK;
case SCISSORS -> other == PAPER; case SCISSORS -> other == PAPER;
case WELL -> other == ROCK || other == SCISSORS;
}; };
return result ? Result.WIN : Result.LOOSE;
} }
} }

View File

@@ -1,8 +0,0 @@
package fr.iut_fbleau.info.but3.automation.rock_paper_scissors.play.domain;
public enum Result {
WIN,
LOOSE,
EQUAL;
}

View File

@@ -9,16 +9,17 @@ import fr.iut_fbleau.info.but3.automation.rock_paper_scissors.stat.domain.StatSa
@DomainService @DomainService
public record RockPaperScissorsPlayer(CpuPick cpuPick, StatSave statSave) implements RockPaperScissorsPlay { public record RockPaperScissorsPlayer(CpuPick cpuPick, StatSave statSave) implements RockPaperScissorsPlay {
public static final String WIN = "WIN";
public static final String LOOSE = "LOOSE";
@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();
Result beats = move.beats(cpuPicked); boolean beats = move.beats(cpuPicked);
if (beats.equals(Result.WIN)) { String result = beats ? WIN : LOOSE;
if (result.equals(WIN)) {
this.statSave.addWin(name); this.statSave.addWin(name);
} }
return new RoundResult(beats.toString(), name, cpuPicked); return new RoundResult(result, name, cpuPicked);
} }
} }

View File

@@ -4,7 +4,6 @@ import fr.iut_fbleau.info.but3.automation.rock_paper_scissors.ddd.DomainService;
import fr.iut_fbleau.info.but3.automation.rock_paper_scissors.ddd.Stub; import fr.iut_fbleau.info.but3.automation.rock_paper_scissors.ddd.Stub;
import fr.iut_fbleau.info.but3.automation.rock_paper_scissors.play.configuration.PlayConfiguration; import fr.iut_fbleau.info.but3.automation.rock_paper_scissors.play.configuration.PlayConfiguration;
import fr.iut_fbleau.info.but3.automation.rock_paper_scissors.play.domain.Move; import fr.iut_fbleau.info.but3.automation.rock_paper_scissors.play.domain.Move;
import fr.iut_fbleau.info.but3.automation.rock_paper_scissors.play.domain.Result;
import fr.iut_fbleau.info.but3.automation.rock_paper_scissors.play.domain.RockPaperScissorsPlayer; import fr.iut_fbleau.info.but3.automation.rock_paper_scissors.play.domain.RockPaperScissorsPlayer;
import fr.iut_fbleau.info.but3.automation.rock_paper_scissors.play.spi.CpuPick; import fr.iut_fbleau.info.but3.automation.rock_paper_scissors.play.spi.CpuPick;
import fr.iut_fbleau.info.but3.automation.rock_paper_scissors.play.spi.FakeCpuPicker; import fr.iut_fbleau.info.but3.automation.rock_paper_scissors.play.spi.FakeCpuPicker;
@@ -25,6 +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.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;
@@ -44,14 +45,14 @@ 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, Result.WIN), Arguments.of(Move.ROCK, Move.SCISSORS, WIN),
Arguments.of(Move.ROCK, Move.PAPER, Result.LOOSE) Arguments.of(Move.ROCK, Move.PAPER, LOOSE)
); );
} }
@ParameterizedTest @ParameterizedTest
@MethodSource("scenario") @MethodSource("scenario")
void shouldReturnWinResult_whenPlayerPlaysRock(Move playerMove, Move cpuMove, Result expectedResult) throws Exception { void shouldReturnWinResult_whenPlayerPlaysRock(Move playerMove, Move cpuMove, String expectedResult) throws Exception {
FakeCpuConfiguration.cpuPick.setNextMove(cpuMove); FakeCpuConfiguration.cpuPick.setNextMove(cpuMove);
mockMvc.perform( mockMvc.perform(
post(PLAY_ENDPOINT) post(PLAY_ENDPOINT)
@@ -63,7 +64,7 @@ public class PlayControllerTest {
""", playerMove)) """, playerMove))
.contentType(MediaType.APPLICATION_JSON_VALUE) .contentType(MediaType.APPLICATION_JSON_VALUE)
).andExpect(status().isOk()) ).andExpect(status().isOk())
.andExpect(jsonPath("$.result").value(expectedResult.toString())) .andExpect(jsonPath("$.result").value(expectedResult))
.andExpect(jsonPath("$.cpu").value(cpuMove.name())); .andExpect(jsonPath("$.cpu").value(cpuMove.name()));
} }

View File

@@ -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;
@@ -15,39 +14,26 @@ class MoveTest {
@Test @Test
void should_check_move_size(){ void should_check_move_size(){
Assertions.assertEquals(4, Move.values().length); Assertions.assertEquals(3, Move.values().length);
} }
@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) {
assertEquals(Result.WIN ,move1.beats(move2)); assertTrue(move1.beats(move2));
} }
@ParameterizedTest(name = "{1} should not beat {0}") @ParameterizedTest(name = "{1} should not beat {0}")
@MethodSource("winnable") @MethodSource("winnable")
void should_loose(Move move1, Move move2) { void should_loose(Move move1, Move move2) {
assertEquals(Result.LOOSE ,move2.beats(move1)); assertFalse(move2.beats(move1));
} }
@ParameterizedTest(name = "{0} should be equal {0}")
@EnumSource(Move.class)
void should_equal(Move move) {
assertEquals(Result.EQUAL,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.PAPER,Move.WELL), Arguments.of(Move.SCISSORS,Move.PAPER)
Arguments.of(Move.SCISSORS,Move.PAPER),
Arguments.of(Move.WELL,Move.ROCK),
Arguments.of(Move.WELL,Move.SCISSORS)
); );
} }
} }

View File

@@ -20,10 +20,9 @@ class RandomCpuPickerTest {
obtainedMoves.add(picker.pick()); obtainedMoves.add(picker.pick());
} }
assertEquals(4, obtainedMoves.size()); assertEquals(3, 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));
} }
} }