Skip to content

cdefy/miage-numres-step1

 
 

Repository files navigation

Sujet : Faire Burger Quizz !

Vous avez 4 séances de TD/TP pour produire un site web qui permettent de répondre à des questions et donne le score.

Notation

  • 2pt de rendu par séance
  • 12 pt de QCM/Questions ouvertes lors du dernier tp (1H dernière seance)

Warning

Noubliez pas de faire votre pullRequest en fin de td/tp

Tip

Il y a des commandes utiles en bas de page.

Environnement

L'ensemble des 4 TD/TP sont à réaliser sur Gitpod.

Gitpod est une plateforme de développement cloud qui permet de configurer des environnements de développement prêts à l’emploi pour tout projet, directement depuis un dépôt Git. Elle automatise la préparation des environnements (dépendances, configurations, etc.), réduisant ainsi le temps d’installation et les problèmes de compatibilité. Grâce à son intégration avec des outils comme GitHub, GitLab, et Bitbucket, Gitpod propose des espaces de travail reproductibles et éphémères.

Déroulement

Dans le monde de l'Open Source, lorsque l'on veut contribuer à un projet, on propose des évolutions à une base de code (un repo) qui seront approuvées ou non par un validateur (reviewer). C'est ce que l'on appel faire une PR.

Vous allez reproduire le processus d'une PR pour chacun des TD/TP.

Ainsi pour chacun des TD/TPS, il faudra:

  1. Dupliquer (Forker) le projet github
  2. Modifier / compléter des fichier du repo. forké
  3. Commiter vos modifs sur votre repo.
  4. Proposer vos modifications sur le repo. parent (PullRequest)

Creation des comptes

Vous allez créer 2 comptes: un sur GitHub et un sur GitPod. Ces comptes seront utilisés lors des 4TD/TP.

GitHub

Dans cette section nous créons un compte sur Github. Si vous en avez déjà vous pouvez passer à l'étape suivante.

  1. Se rendre sur https://github.com
  2. Bouton Sign up Github1
  3. Remplissez le formulaire d'inscription Github1
  4. Connecter vous au site github avec le nouveau compte créé
  5. Remplissez le formulaire Github1

Gitpod

Creation compte

  1. Se rendre sur https://gitpod.io/login, selectionner Gitpod classic (PAS FLEX) et se connecter avec Github Github1
  2. Authoriser Gitpod à accèder à votre compte Github Github1
  3. Sélectionner la formule à 1Ohrs/mois Github1
  4. Préciser que vous etes étudiant Github1

Configuration du compte

Il faut ajouter à votre compte gitpod le droit de pouvoir lire&ecrire sur vos repos github.

  1. Se connecter à votre compte Gitpod
  2. Se rendre dans votre paramètres de comptes Github1
  3. Editer les paramètres de vote liaison à Github dans le menu 'Git Provider' Github1
  4. Ajouter le droit de lecture/ecriture à vos repos à travers Gitpod Github1

Fork du projet

L'objectif est de créer une copie du projet 'miage-numres-step1' sur votre compte github.

  1. Se rendre sur le projet github [miage-numres-step1] (https://github.com/aepsilon-tek/miage-numres-step1)
  2. Fork du projet grâce au bouton

Capture d'écran Capture d'écran

TP1 - Stack Back-End

L'architecture générale de l'application Burger Quizz est la suivante : Capture d'écran

Une application web consomme une API Rest qui s'appuie sur une base de données relationnelles en mémoire H2.

Ce TP1 doit permettre de choisir la stack d'implementation de l'api. Le choix est à faire entre Springboot et Quarkus.

Utiliser gitpod

Pour utiliser GitPod avec votre projet forké, il suffit d'ouvrir l'url suivant dans votre navigateur : https://gitpod.io/# + URL_REPO_GITHUB

Avec un repo https://github.com/miage3-ae/miage-numres-step1 alors l'url est : https://gitpod.io/#https://github.com/miage3-ae/miage-numres-step1

Avec l'exemple ci-dessus et étant connecté à GitPod avec votre compte, vous devez obtenir cette fenêtre:

Capture d'écran

Vous êtes désormais connecté à votre environnement de developpement.

Test de commit

  1. Répondez aux questions Q1 et Q2 dans le fichier Questions.md
  2. Commiter & Pusher
  3. Vérifier sur le site github que dans votre repo le fichier Questions.md contient bien vos modifications

API Springboot

Developpement

  1. Lancer application springboot en mode développement dans un Terminal
  2. Tester dans un second Terminal que l'api répond : curl -w "\n" http://localhost:8080/api/hello
  3. Modifier le contenu du message renvoyé
  4. Tester que la modification fonctionne
  5. Commiter & Pusher la modification du fichier

Packaging de l'app, execution et mesures

  1. Dans le terminal, construire l'application springboot
  2. Lancer la commande java -jar api-springboot/target/api-springboot-0.0.1-SNAPSHOT.jar
  3. Tester que l'Api répond
  4. Mesurer la mémoire consommer par l'api SpringBoot ps -e -o pid,rss,args | grep api-springboot Répondre aux questions Q3,Q4,Q5 et Q6 du fichier Questions.md
  5. Commiter & Pusher le fichier Questions.md

API Quarkus

Developpement

  1. Lancer application quarkus en mode développement dans un Terminal
  2. Tester dans un second Terminal que l'api répond : curl -w "\n" http://localhost:8080/hello
  3. Modifier le contenu du message renvoyé
  4. Tester que la modification fonctionne
  5. Commiter & Pusher la modification du fichier

Packaging de l'app, execution et mesures

  1. Dans le terminal, construire l'application quarkus en mode JVM

  2. Lancer la commande java -jar api-quarkus/target/quarkus-app/quarkus-run.jar

  3. Mesurer la mémoire consommer par l'api quarkus ps -e -o pid,rss,args | grep quarkus-run Répondre aux questions Q7,Q8 et Q9 du fichier Questions.md

  4. Dans le terminal, construire l'application quarkus en mode Natif

  5. Lancer la commande ./api-quarkus/target/api-quarkus-1.0.0-SNAPSHOT-runner

  6. Mesurer la mémoire consommer par l'api quarkus ps -e -o pid,rss,args | grep runner Répondre aux questions Q10,Q11 du fichier Questions.md

  7. Commiter & Pusher le fichier Questions.md

Pull Request

Une fois tous vos commits & Push réalisés sur votre repo, il est nécessaire de faire la Pull Request sur le repo parent. Pour cela, il suffit de :

  1. Se rendre sur votre compte personnel sur GitHub.
  2. Sur la page principale, se rendre sur Contribute > Open pull Request Capture d'écran
  3. Remplir le titre de la pull request en précisant votre nom (vos noms) et Create pull request Capture d'écran

Commandes Utiles

  • ./mvnw clean compile : Compilation des 2 modules (api-quarkus et api-springboot ) du projet
  • ./mvnw spring-boot:run -pl api-springboot : Lancement du projet api-springboot en mode developpement
  • ./mvnw clean package -pl api-springboot : Construction du projet api-springboot
  • ./mvnw quarkus:dev -pl api-quarkus : Lancement du projet api-quarkus en mode developpement
  • ./mvnw clean package -pl api-quarkus : Construction du projet api-quarkus en mode JVM
  • ./mvnw clean package -P native -pl api-quarkus : Construction du projet api-quarkus en mode Natif

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Java 100.0%