Skip to content

amiara514/entrevueSpringBoot

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

1 Commit
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Test Analyste-Programmeur (Java Spring Boot)

Objectif du test

Votre objectif pour ce test est de créer un API Rest avec Java et Spring Boot pour ajouter et obtenir les détails d'un film.

Vous devez créer 2 endpoints dans l'API:

  • Un GET pour obtenir un film par ID dans la base de données en mémoire (H2).
  • Un POST pour ajouter un film dans la base de données en mémoire (H2).

Présomptions

  • 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é.

Critères

  • 2 endpoints REST fonctionnels
  • Structure des classes
  • Qualité du code
  • Utilisation des meilleurs pratiques
  • Écriture des tests unitaires selon les meilleurs pratiques

Outils à utiliser

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.

  • Java 11
  • Gradle
  • Spring Boot
  • Spring Data JPA
  • Base de donnée en mémoire H2
  • Junit pour test unitaire
  • Lombok (Optionnel)
  • Mapstruct (Optionnel)
  • Cucumber(Optionnel pour la BDD)

Modèle

Film

{
    "id": long,
    "titre": string,
    "description": string
    "acteurs": [
        {
            "id": long,
            "nom": string,
            "prenom": string
        }
    ]
}

Endpoints

GET /api/films/{id}

  • Requête: ID dans l'URI
  • Réponse: Objet Film (Voir modèle)
  • Status: 200 OK
http://localhost:8080/api/films/1
{
   "id":1,
   "titre":"Star Wars: The Empire Strikes Back",
   "description":"Darth Vader is adamant about turning Luke Skywalker to the dark side.",
   "acteurs":[
      {
         "id":2,
         "nom":"Ford",
         "prenom":"Harrison"
      },
      {
         "id":3,
         "nom":"Hamill",
         "prenom":"Mark"
      }
   ]
}

POST /api/films

  • Requête: Objet Film dans le body
  • Réponse: Objet Film crée
  • Status: 201 CREATED
'{
   "titre":"Star Wars: The Empire Strikes Back",
   "description":"Darth Vader is adamant about turning Luke Skywalker to the dark side.",
   "acteurs":[
      {
         "nom":"Ford",
         "prenom":"Harrison"
      },
      {
         "nom":"Hamill",
         "prenom":"Mark"
      }
   ]
}'
http://localhost:8080/api/films --header "Content-Type:application/json"

{
   "id":4,
   "titre":"Star Wars: The Empire Strikes Back",
   "description":"Darth Vader is adamant about turning Luke Skywalker to the dark side.",
   "acteurs":[
      {
         "id":5,
         "nom":"Ford",
         "prenom":"Harrison"
      },
      {
         "id":6,
         "nom":"Hamill",
         "prenom":"Mark"
      }
   ]
}

Validation des endpoints

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.

Soumettre le test

Une fois terminé, veuillez créer un nouveau dépot sur GitHub et l'envoyer par courriel.

Bonne chance!

About

Spring Boot test

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages