on
JavaScript Basics Lab
JS Basics Lab
Le code source nécessaire à ce tp se trouve sur la forge de L’université : https://www-apps.univ-lehavre.fr/forge/2024-2025-m1/WEB-jsbasics-lab
Ce projet est principalement constitué de fichiers de tests (test/index.test.js
et test/circle.test.js
) qui s’appliquent sur un ensemble de fonctions (fichiers src/index.js
src/circle.js
). Certains tests sont écrits, mais le corps des fonctions testées est vide ! D’autres fonctions sont écrites mais il faut écrire leurs testes. Parfois il manque le corps des fonctions et les tests.
Travail à réaliser
- Se connecter à la forge de l’université avec son propre login (se connecter avec le CAS de l’université la première fois). Bien s’assurer que GIT est correctement configuré. Pour plus d’information sur GIT, GitLab et la forge de l’université, se référer au cours introductif au travail en équipe à l’université.
- “Forker” ou “diverger” le projet (bouton “Fork” ou “Divergence”).
-
Cloner son propre projet dans une copie de travail locale en utilisant le schema d’URL
https
(git clone https://www-apps.univ-lehavre.fr/forge/LOGIN/WEB-jsbasics-lab.git
) (sans oublier de changerLOGIN
par votre login). - Modifier le fichier README.md du projet pour y faire apparaître vos coordonnées (nom, prénom, login, email).
-
Dans la copie de travail exécuter la commande
npm install
ounpm i
pour installer les dépendances du projet. -
Lancer les tests :
npm test
ounpm t
-
Il y a beaucoup d’erreurs. A vous de les corriger en écrivant le corps des fonctions dans les fichiers
src/index.js
etsrc/circle.js
(à la place des commentaires/* TODO */
) et en relançant les tests. Faire des commits au fur et à mesure que vous validez des tests. (git add -u && git commit
) -
A l’inverse certaines fonctions sont écrites dans
src/index.js
mais ne sont pas testées. A vous d’écrire les tests danssrc/index.test.js
afin de maximiser le taux de couverture des tests. Le taux de couverture s’affiche en ligne de commande dans le tableau à la fin des tests. Pour avoir des infos détaillées on peut ouvrir le fichiercoverage/lcov-report/index.html
dans un navigateur pour comprendre quelles lignes et quelles branches ont été oubliées. Faire des commits au fur et à mesure que vous écrivez les tests.
Le style du code écrit est également testé. Les tests ne s’exécuteront pas si le code ne respectent pas les règles syntaxiques définies. On utilise les règles recommandées (eslint:recommended
) par le projet ESLint.
Fin du travail
Quand tous les tests passent, que la couverture du code par les tests est satisfaisante (100%, 99%, 98%, …?) et que les modifications sont enregistrées (avec des commit
) :
- publiez votre projet :
git push
. Cela aura pour conséquence, en plus de publier vos modifications sur votre version du projet, de lancer l’exécution des tests unitaires sur le serveur d’intégration continue de la forge. - créez un merge request pour que je puisse évaluer votre travail.
technologies utilisées
- Ce projet est écrit en ES6.
- le code est compilé en ES5 par babel.
- Le respect des règles syntaxiques est effectué par ESLint.
- L’outils permettant l’exécution des tests est la plateforme Jest.
- NPM est utilisé pour la gestion des dépendances et l’exécution des différents scripts.
Échéance
TP à rendre pour le :
- 04/02/2025