Votre objectif pour ce test est de créer un API Rest avec Java et Spring Boot pour ajouter et obtenir les joueurs et les informations de l'équipe de Hockey des Canadiens du Montréal. Le but est donc d'avoir la composition de cette équipe pour chaque année ou elle a participé à la Ligue Nationale de Hockey.
Vous devez créer les endpoints suivants dans l'API:
- Un GET pour obtenir la composition de l’équipe en fonction de l'année dans la base de données en mémoire (H2).
- Un POST pour t'ajouter en tant que nouveau joueur de l'équipe d'une année définie dans la base de données en mémoire (H2).
- Un PUT pour mettre à jour le capitaine de l'equipe pour une année définie
- Ne vous souciez pas de valider l'entrée de l'utilisateur, vous pouvez présumer que la requête sera toujours valide.
- Il n'est pas nécessaire d'implémenter un mécanisme de sécurité.
- Il n'est pas nécessaire d'écrire des tests unitaires.
- 3 endpoints REST fonctionnels
- Structure des classes
- Qualité du code
- Utilisation des meilleurs pratiques de développement
Le projet contient déjà les dépendances Maven requises et la configuration nécessaire pour H2.
Vous avez aussi, optionnellement, la possibilité d'utiliser les librairies Lombok et MapStruct si vous le désirez (Hors kotlin).
- Java 11 ou Kotlin
- Maven
- Spring Boot
- Spring Data JPA
- Base de donnée en mémoire H2
- Lombok (Optionnel)
- Mapstruct (Optionnel)
Team
{
"id": long,
"coach": string
"year" : long
"players": [
{
"number": long,
"name": string,
"lastname": string,
"position":"defenseman",
"isCaptain" : boolean
}
]
}
-
Requête: Year dans l'URI
-
Réponse: Objet Team (Voir modèle ci-dessus)
-
Status: 200 OK
http://localhost:8080/api/team/2020 { "id":2, "coach":"Dominique Ducharme", "year":"2020", "players":[ { "number":31, "name":"Carey", "lastname":"Price", "position":"goaltender" }, { "number":14, "name":"Nick", "lastname":"Suzuki", "position":"forward" }, { "number":15, "name":"Jesperi", "lastname":"Kotkaniemi", "position":"forward" }, { "number":71, "name":"Jake", "lastname":"Evans", "position":"forward" }, { "number":27, "name":"Alexander", "lastname":"Romanov", "position":"defenseman" }, { "number":6, "name":"Shea", "lastname":"Weber", "position":"defenseman", "isCaptain" : true } ] }
http://localhost:8080/api/team/2019 { "id":1, "coach":"Dominique Ducharme", "year":"2019", "players":[ { "number":31, "name":"Carey", "lastname":"Price", "position":"goaltender" }, { "number":14, "name":"Nick", "lastname":"Suzuki", "position":"forward" }, { "number":15, "name":"Jesperi", "lastname":"Kotkaniemi", "position":"forward" }, { "number":71, "name":"Jake", "lastname":"Evans", "position":"forward" }, { "number":27, "name":"Alexander", "lastname":"Romanov", "position":"defenseman" }, { "number":6, "name":"Shea", "lastname":"Weber", "position":"defenseman", "isCaptain" : true } ] }
- Requête: Objet Joueur dans le body
- Réponse: Objet Joueur crée
- Status: 201 CREATED
http://localhost:8080/api/player --header "Content-Type:application/json"
{
"number":99,
"name":"Marion",
"lastname":"Félix",
"position":"forward",
"isCaptain" : false
}
- Requête: ID du joueur dans l'URI
- Réponse: Objet Player
- Status: 200 OK
Vous pouvez utiliser la collection postman incluse dans le projet si vous désirez valider votre API avec des assertions.
Celle-ci se retrouve dans le dossier postman du projet.
Une fois terminé, veuillez créer un nouveau dépot sur GitHub et l'envoyer par courriel.
Bonne chance et bon game ! 🏒