Sujet de leadership
Amélioration des tests fronts à la BPI
🧑💻
La DevX n'est pas "bonne"
(lisibilité / écriture)
Problème
🛡️
Tests peu efficaces pour empêcher certaines régressions
🛡️
Tests peu efficaces pour empêcher certaines régressions
Pourquoi ?
On ne teste pas les interactions utilisateurs
On ne teste les composants qu' unitairement
🧑💻
La DevX n'est pas "bonne"
Pourquoi ?
Les tests sont plutôt longs à écrire
Une refacto sans changement métier impose des changements dans les tests
Compliqué de comprendre ce que fait un composant en lisant les tests
Pourquoi on ne fait pas mieux ?
On utilise Jasmine
permet de tester unitairement l'implémentation de chaque composant
Conséquence : outil qui n'est pas adapté pour tester les interactions utilisateurs
Exemples
MR du 07/10/2022
Tester la présence / l'absence d'éléments sur la page
Très difficile à faire avec Jasmine, qui n'est pas fait pour
ATL est fait pour ça
Bug
Bug du 10/10/2022
Tester des comportements de composants complexes
On en est où ?
Sur mon projet (Aldrin)
Jasmine
Jest
Angular Testing Library
✅
⏳️
On en est où ?
Sur mon projet (Aldrin) - Stratégie
- 1800 tests répartis sur 180 fichiers
-
Tout nouveau fichier de composant doit être testé avec ATL (pokayoke : blocage CI)
-
Migration des anciens fichiers de tests pendant les journées qualité
On en est où ?
A la BPI
25 août
20 septembre
12 octobre
Ecritures de standards ATL
Formation des autres équipes travaillant sur BRI
jasmine & ATL sur frontend-main
jest et ATL sur
frontend-boost (migration)
jest et ATL sur frontend-imc (new)
Migration vers Jest
1800 tests
~ 11 JH
En comparaison, pour boost 300 tests pour 2 JH
Migration vers Jest
stratégie brute force
REX
stratégie progressive
Perte de temps (nombreux conflits)
Démotivation
Moins de conflits
Petit coût à l'entrée
Migration vers Jest
REX
Migration vers Jest a des avantages
- Utilisation de librairies compatibles
-
Standard à Theodo
Coût est important pour un gros projet (+ de 500 tests)
Migration vers Jest
Gros projets
Petit projets
Migration vers ATL depuis Jasmine
Migration vers Jest puis ATL
frontend-main
frontend-boost
frontend-imc
up-expert
By Théo Dollé
up-expert
- 169