Test Agile - Guide rapide
Agileest une méthodologie de développement itérative, où les activités de développement et de test sont simultanées. Le test n'est pas une phase distincte; Le codage et les tests sont effectués de manière interactive et incrémentielle, ce qui donne un produit final de qualité, qui répond aux exigences du client. En outre, l'intégration continue permet une élimination précoce des défauts et donc des économies de temps, d'efforts et de coûts.
Manifeste Agile
Le Manifeste Agile a été publié par une équipe de développeurs de logiciels en 2001, soulignant l'importance de l'équipe de développement, tenant compte de l'évolution des exigences et de l'implication des clients.
The Agile Manifesto is −
Nous découvrons de meilleures façons de développer des logiciels en le faisant et en aidant les autres à le faire. Grâce à ce travail, nous en sommes venus à valoriser -
- Les individus et les interactions sur les processus et les outils.
- Logiciel de travail sur une documentation complète.
- Collaboration client sur négociation de contrat.
- Répondre au changement au sujet d'un plan.
Autrement dit, bien qu'il y ait de la valeur dans les éléments de droite, nous valorisons davantage les éléments de gauche.
Qu'est-ce que le test agile?
Le test agile est une pratique de test logiciel qui suit les principes du développement logiciel agile.
Les tests agiles impliquent tous les membres de l'équipe de projet, avec une expertise particulière apportée par les testeurs. Les tests ne sont pas une phase distincte et sont liés à toutes les phases de développement telles que les exigences, la conception et le codage et la génération de cas de test. Les tests ont lieu simultanément tout au long du cycle de vie du développement.
En outre, avec des testeurs participant à l'ensemble du cycle de vie du développement en collaboration avec des membres de l'équipe interfonctionnelle, la contribution des testeurs à la construction du logiciel selon les exigences du client, avec une meilleure conception et un meilleur code deviendrait possible.
Les tests agiles couvrent tous les niveaux de tests et tous les types de tests.
Vs tests agiles. Test en cascade
Dans une méthodologie de développement en cascade, les activités du cycle de vie du développement se déroulent en phases séquentielles. Ainsi, les tests sont une phase distincte et ne sont lancés qu'après l'achèvement de la phase de développement.
Voici les points saillants des différences entre les tests agiles et les tests en cascade -
Test agile | Test en cascade |
---|---|
Les tests ne constituent pas une phase distincte et se produisent en même temps que le développement. | Le test est une phase distincte. Tous les niveaux et types de tests ne peuvent commencer qu'après la fin du développement. |
Les testeurs et les développeurs travaillent ensemble. | Les testeurs travaillent séparément des développeurs. |
Les testeurs participent à l'élaboration des exigences. Cela aide à mapper les exigences sur les comportements dans le scénario du monde réel et à définir les critères d'acceptation. En outre, les cas de test d'acceptation logiques seraient prêts avec les exigences. | Les testeurs peuvent ne pas être impliqués dans la phase des exigences. |
Les tests d'acceptation sont effectués après chaque itération et les commentaires des clients sont recherchés. | Les tests d'acceptation sont effectués uniquement à la fin du projet. |
Chaque itération complète ses propres tests, permettant ainsi la mise en œuvre des tests de régression à chaque fois que de nouvelles fonctions ou logiques sont publiées. | Les tests de régression ne peuvent être mis en œuvre qu'après la fin du développement. |
Aucun délai entre le codage et les tests. | Délais habituels entre le codage et les tests. |
Test continu avec des niveaux de test qui se chevauchent. | Le test est une activité chronométrée et les niveaux de test ne peuvent pas se chevaucher. |
Le test est une bonne pratique. | Les tests sont souvent négligés. |
Principes de test agile
Les principes du test Agile sont:
Testing moves the project forward- Les tests continus sont le seul moyen d'assurer un progrès continu. Les tests agiles fournissent des commentaires sur une base continue et le produit final répond aux exigences de l'entreprise.
Testing is not a phase- Une équipe Agile teste aux côtés de l'équipe de développement pour s'assurer que les fonctionnalités implémentées au cours d'une itération donnée sont effectivement réalisées. Les tests ne sont pas conservés pour une phase ultérieure.
Everyone tests- Dans les tests agiles, toute l'équipe, y compris les analystes, les développeurs et les testeurs, teste l'application. Après chaque itération, même le client effectue le test d'acceptation de l'utilisateur.
Shortening Feedback Loops- Dans Agile Testing, l'équipe commerciale apprend à connaître le développement de produit pour chaque itération. Ils sont impliqués dans chaque itération. La rétroaction continue raccourcit le temps de réponse de la rétroaction et donc le coût impliqué dans sa correction est moindre.
Keep the Code Clean- Les défauts sont corrigés car ils sont soulevés dans la même itération. Cela garantit un code propre à chaque étape du développement.
Lightweight Documentation - Au lieu d'une documentation de test complète, les testeurs Agile -
Utilisez des listes de contrôle réutilisables pour suggérer des tests.
Concentrez-vous sur l'essence du test plutôt que sur les détails accessoires.
Utilisez des styles / outils de documentation légers.
Capturez des idées de test dans des chartes pour des tests exploratoires.
Tirez parti des documents à des fins multiples.
Leveraging one test artifact for manual and automated tests- Le même artefact de script de test peut être utilisé pour les tests manuels et comme entrée pour les tests automatisés. Cela élimine la nécessité d'une documentation de test manuel, puis d'un script de test d'automatisation équivalent.
“Done Done,” not just done - En Agile, on dit qu'une fonctionnalité n'est pas effectuée après le développement mais après le développement et les tests.
Test-Last vs. Test Driven- Les cas de test sont rédigés avec les exigences. Par conséquent, le développement peut être piloté par des tests. Cette approche s'appelle Test Driven Development (TDD) et Acceptance Test Driven Development (ATDD). Cela contraste avec les tests en tant que dernière phase des tests en cascade.
Activités de test agile
Les activités de test agile au niveau du projet sont:
Planification de la version (plan de test)
Pour chaque itération,
Activités de test agile pendant une itération
Les tests de régression
Activités de lancement (liées au test)
Les activités de test Agile pendant une itération comprennent:
- Participer à la planification des itérations
- Estimation des tâches du point de vue des tests
- Rédaction de cas de test à l'aide des descriptions de fonctionnalités
- Test unitaire
- Test d'intégration
- Test des fonctionnalités
- Correction des défauts
- Test d'intégration
- Test d'acceptation
- Rapports d'état sur l'avancement des tests
- Suivi des défauts
Agile est une méthodologie de développement itérative, où toute l'équipe du projet participe à toutes les activités. Les exigences évoluent au fil des itérations, grâce à la collaboration entre le client et les équipes auto-organisées. Comme le codage et les tests sont effectués de manière interactive et incrémentielle, au cours du développement, le produit final serait de qualité et répondrait aux exigences du client.
Chaque itération entraîne un incrément de produit fonctionnel intégré et est fournie pour les tests d'acceptation par l'utilisateur. Les commentaires des clients ainsi obtenus seraient une entrée pour les itérations suivantes / suivantes.
Intégration continue, qualité continue
L'intégration continue est la clé du succès du développement Agile. Intégrez fréquemment, au moins quotidiennement, de sorte que vous soyez prêt pour une version en cas de besoin. Les tests en Agile deviennent une composante essentielle de toutes les phases du développement, garantissant une qualité continue du produit. Un retour d'information constant de toutes les personnes impliquées dans le projet ajoute à la qualité du produit.
Dans Agile, la communication a la plus haute importance et les demandes des clients sont reçues en tant que de besoin. Cela donne la satisfaction au client que toutes les entrées sont prises en compte et qu'un produit de qualité de travail est disponible tout au long du développement.
Méthodologies Agiles
Il existe plusieurs méthodologies Agile qui prennent en charge le développement Agile. Les méthodologies Agile comprennent -
Scrum
Scrum est une méthode de développement Agile qui met l'accent sur une approche centrée sur l'équipe. Il préconise la participation de toute l'équipe à toutes les activités de développement du projet.
XP
eXtreme Programming est centré sur le client et se concentre sur des exigences en constante évolution. Avec des versions fréquentes et des commentaires des clients, le produit final sera de qualité répondant aux exigences des clients qui sont plus claires au cours du processus.
Cristal
Crystal est basé sur l'affrètement, la livraison cyclique et la conclusion.
L'affrètement consiste à former une équipe de développement, à effectuer une analyse de faisabilité préliminaire, à arriver à un plan initial et à la méthodologie de développement.
La livraison cyclique avec deux ou plusieurs cycles de livraison se concentre sur la phase de développement et la livraison finale du produit intégré.
Lors de la finalisation, le déploiement dans l'environnement utilisateur, les revues et réflexions post-déploiement sont effectuées.
FDD
Le développement axé sur les fonctionnalités (FDD) implique la conception et la création de fonctionnalités. La différence entre FDD et les autres méthodologies de développement Agile est que les fonctionnalités sont développées séparément en phases spécifiques et courtes.
DSDM
La méthode de développement logiciel dynamique (DSDM) est basée sur le développement rapide d'applications (RAD) et est alignée sur le cadre Agile. DSDM se concentre sur la livraison fréquente du produit, impliquant activement les utilisateurs et permettant aux équipes de prendre des décisions rapides.
Développement de logiciels Lean
Dans le développement de logiciels Lean, l'accent est mis sur l'élimination du gaspillage et la valorisation du client. Cela se traduit par un développement rapide et un produit de valeur.
Les déchets comprennent les travaux partiellement exécutés, les travaux non pertinents, les fonctionnalités non utilisées par le client, les défauts, etc. qui s'ajoutent aux retards de livraison.
le Lean Principles sont -
- Éliminer les déchets
- Amplifier l'apprentissage
- Engagement de retard
- Habilitez l'équipe
- Livrer rapidement
- Construire l'intégrité dans
- Voir le tout
Kanban
Kanban se concentre sur la gestion du travail en mettant l'accent sur la livraison juste à temps (JIT), sans surcharger les membres de l'équipe. Les tâches sont affichées pour que tous les participants puissent les voir et pour que les membres de l'équipe extraient le travail d'une file d'attente.
Kanban est basé sur -
- Tableau Kanban (visuel et persistant tout au long du développement)
- Limite des travaux en cours (WIP)
- Délai de mise en œuvre
Méthodologies de test agile
Les pratiques de test sont bien définies pour chaque projet, qu'il soit Agile ou non, afin de livrer des produits de qualité. Les principes de test traditionnels sont assez souvent utilisés dans les tests agiles. L'un d'eux est Early Testing qui se concentre sur -
Rédaction de cas de test pour exprimer le comportement du système.
Prévention précoce des défauts, détection et élimination.
S'assurer que les bons types de tests sont exécutés au bon moment et dans le cadre du bon niveau de test.
Dans toutes les méthodologies Agile dont nous avons discuté, le test Agile est en soi une méthodologie. Dans toutes les approches, les cas de test sont écrits avant le codage.
Dans ce tutoriel, nous nous concentrerons sur Scrum en tant que méthodologie de test agile.
Les autres méthodologies de test Agile couramment utilisées sont:
Test-Driven Development (TDD) - Le développement piloté par les tests (TDD) est basé sur un codage guidé par des tests.
Acceptance Test-Driven Development (ATDD) - Le développement piloté par les tests d'acceptation (ATDD) est basé sur la communication entre les clients, les développeurs et les testeurs et conduit par des critères d'acceptation et des cas de test d'acceptation prédéfinis.
Behavior-Driven Development (BDD) - Les tests BDD (Behavior-Driven Development) sont basés sur le comportement attendu du logiciel en cours de développement.
Cycle de vie des tests agiles
Dans Scrum, les activités de test incluent -
Contribuer aux User Stories en fonction du comportement attendu du système représenté sous forme de cas de test
Planification des versions basée sur l'effort de test et les défauts
Planification de sprint basée sur les histoires d'utilisateurs et les défauts
Exécution de sprint avec tests continus
Test de régression après la fin du Sprint
Rapport des résultats des tests
Test d'automatisation
Les tests sont itératifs et basés sur les sprints comme illustré dans le diagramme ci-dessous -
Le développement Agile est centré sur l'équipe et les développeurs et les testeurs participent à toutes les activités de projet et de développement. Le travail d'équipe maximise le succès des tests dans les projets Agile.
Une équipe Tester in Agile doit participer et contribuer à toutes les activités du projet et doit en même temps tirer parti de l'expertise en matière de tests.
Un testeur Agile doit avoir des compétences de test traditionnelles. De plus, le testeur Agile a besoin de -
Bonnes compétences interpersonnelles.
Capacité à agir de manière positive et axée sur les solutions avec les membres de l'équipe et les parties prenantes.
Capacité à afficher une réflexion critique, axée sur la qualité et sceptique sur le produit.
Aptitude à être pro-actif pour acquérir activement des informations auprès des parties prenantes.
Compétences pour travailler efficacement avec les clients et les parties prenantes dans la définition des User Stories testables, les critères d'acceptation.
Talent pour être un bon membre de l'équipe travaillant avec les développeurs dans la production de code de qualité.
Convivialité des compétences de test pour avoir les bons cas de test au bon moment et au bon niveau et bien les exécuter pendant la durée du sprint.
Capacité d'évaluer et de rapporter les résultats des tests, la progression des tests et la qualité du produit.
Ouverture pour répondre rapidement aux changements, y compris changer, ajouter ou améliorer des cas de test.
Potentiel d'auto-organisation du travail.
Enthousiasme pour la croissance continue des compétences.
Compétence en automatisation des tests, développement piloté par les tests (TDD), développement piloté par les tests d'acceptation (ATDD), développement piloté par le comportement (BDD) et tests basés sur l'expérience.
Rôle du testeur dans l'équipe Agile
Tester in Agile Team participe à toutes les activités de projet et de développement pour apporter le meilleur de l'expertise de test.
Les activités de testeur agile comprennent:
Assurer une bonne utilisation des outils de test.
Configuration, utilisation et gestion des environnements de test et des données de test.
Encadrement d'autres membres de l'équipe dans les aspects pertinents des tests.
S'assurer que les tâches de test appropriées sont planifiées pendant la planification de la version et du sprint.
Comprendre, mettre en œuvre et mettre à jour la stratégie de test.
Collaborer avec les développeurs, les clients et les parties prenantes pour clarifier les exigences, en termes de testabilité, de cohérence et d'exhaustivité.
Effectuer les bons tests au bon moment et aux bons niveaux de test.
Signaler les défauts et travailler avec l'équipe pour les résoudre.
Mesurer et rapporter la couverture de test pour toutes les dimensions de couverture applicables.
Participer à des rétrospectives de sprint, proposer et mettre en œuvre des améliorations de manière proactive.
Dans le cycle de vie Agile, un testeur joue un rôle important dans -
- Teamwork
- Planification des tests
- Sprint zéro
- Integration
- Pratiques de tests agiles
Travail en équipe
Dans le développement Agile, le travail d'équipe est fondamental et nécessite donc ce qui suit -
Collaborative Approach- Travailler avec les membres de l'équipe interfonctionnelle sur la stratégie de test, la planification des tests, la spécification des tests, l'exécution des tests, l'évaluation des tests et le rapport des résultats des tests. Contribuer à l'expertise des tests en conjonction avec d'autres activités de l'équipe.
Self-organizing - Bien planifier et organiser les sprints pour atteindre les objectifs des tests en fusionnant également l'expertise d'autres membres de l'équipe.
Empowerment - Prendre les décisions techniques appropriées pour atteindre les objectifs de l'équipe.
Commitment - S'engager à comprendre et évaluer le comportement et les caractéristiques du produit tel que requis par les clients et les parties prenantes.
Transparent - Ouvert, communicant et responsable.
Credibility- Assurer la crédibilité de la stratégie de test, sa mise en œuvre et son exécution. Tenir les clients et les parties prenantes informés sur la stratégie de test.
Open to Feedback- Participer à des rétrospectives de sprint pour apprendre des succès et des échecs. Rechercher les commentaires des clients et agir rapidement et de manière appropriée pour garantir des livrables de qualité.
Resilient - Répondre aux changements.
Planification des tests
La planification des tests doit commencer pendant la planification de la version et se mettre à jour à chaque sprint. La planification des tests doit couvrir les tâches suivantes -
Définition de la portée du test, de l'étendue des tests, des objectifs de test et de sprint.
Décider de l'environnement de test, des outils de test, des données de test et des configurations.
Attribution de tests de fonctionnalités et de caractéristiques.
Planification des tâches de test et définition de la fréquence des tests.
Identifier les méthodes de test, les techniques, les outils et les données de test.
Vérifier les conditions préalables telles que les tâches précédentes, l'expertise et la formation.
Identifier les dépendances telles que les fonctions, le code, les composants système, le fournisseur, la technologie, les outils, les activités, les tâches, les équipes, les types de test, les niveaux de test et les contraintes.
Définition des priorités en tenant compte de l'importance et des dépendances du client / utilisateur.
Arriver à l'heure, durée et effort requis pour tester.
Identifier les tâches à chaque planification de sprint.
Sprint zéro
Sprint Zero implique des activités de préparation avant le premier sprint. Un testeur doit collaborer avec l'équipe sur les activités suivantes -
- Identifier la portée
- Diviser les user stories en sprints
- Créer une architecture système
- Planification, acquisition et installation d'outils (y compris les outils de test)
- Création de la stratégie de test initiale pour tous les niveaux de test
- Définition des métriques de test
- Spécification des critères d'acceptation, également appelée définition de «Terminé»
- Définition des critères de sortie
- Créer un tableau Scrum
- Définition de la direction des tests tout au long des sprints
L'intégration
Dans Agile, un produit fonctionnel de qualité doit être prêt à être publié à tout moment du cycle de vie du développement. Cela implique une intégration continue dans le cadre du développement. Un testeur Agile doit prendre en charge l'intégration continue avec des tests continus.
Pour ce faire, un testeur doit:
- Comprenez la stratégie d'intégration.
- Identifiez toutes les dépendances entre les fonctions et les fonctionnalités.
Pratiques de tests agiles
Un testeur Agile doit adapter les pratiques Agile pour les tests dans un projet agile.
Pairing- Deux membres de l'équipe travaillent ensemble sur le même clavier. En tant que l'un d'eux teste, l'autre examine / analyse les tests. Les deux membres de l'équipe peuvent être
Un testeur et un développeur
Un testeur et un analyste commercial
Deux testeurs
Incremental Test Design - Les cas de test sont construits à partir des user stories, en commençant par des tests simples et en passant à des tests plus complexes.
Mind Mapping- Une carte mentale est un diagramme pour organiser visuellement les informations. La cartographie mentale peut être utilisée comme un outil efficace dans les tests Agile, en utilisant les informations concernant les sessions de test nécessaires, les stratégies de test et les données de test peuvent être organisées.
L'état du test peut être communiqué -
- Lors de réunions quotidiennes debout
- Utilisation d'outils de gestion de test standard
- Via les messagers
Le statut du test déterminé par le statut de réussite du test est crucial pour décider si la tâche est «Terminée». Terminé signifie que tous les tests de la tâche sont réussis.
Progression du test
La progression du test peut être suivie en utilisant -
- Tableaux Scrum (tableaux de tâches agiles)
- Graphiques Burndown
- Résultats des tests automatisés
La progression des tests a également un impact direct sur la progression du développement. En effet, une User Story peut être déplacée versDonestatut uniquement après que les critères d'acceptation sont atteints. Ceci, à son tour, est décidé par le statut de test car les critères d'acceptation sont jugés par un statut de test.
S'il y a des retards ou des blocages dans la progression du test, toute l'équipe discute et travaille en collaboration pour résoudre le même problème.
Dans les projets Agile, les changements ont lieu assez souvent. Lorsque de nombreux changements ont lieu, nous pouvons nous attendre à ce que l'état du test, la progression du test et la qualité du produit évoluent constamment. Les testeurs Agile doivent transmettre ces informations à l'équipe afin que les décisions appropriées puissent être prises au bon moment pour rester sur la bonne voie pour la réussite de chaque itération.
Lorsque des modifications se produisent, elles peuvent affecter les fonctionnalités existantes des itérations précédentes. Dans de tels cas, les tests manuels et automatisés doivent être mis à jour pour faire face efficacement au risque de régression. Des tests de régression sont également nécessaires.
La qualité des produits
Les indicateurs de qualité du produit incluent -
- Tests réussis / échoués
- Défauts détectés / corrigés
- Couverture de test
- Taux de réussite / échec des tests
- Taux de détection des défauts
- Densité de défaut
L'automatisation de la collecte et du reporting des mesures de qualité des produits aide à -
- Maintenir la transparence.
- Rassembler toutes les métriques pertinentes et requises au bon moment.
- Rapports immédiats sans délais de communication.
- Permettre aux testeurs de se concentrer sur les tests.
- Filtrage de l'utilisation abusive des métriques.
Pour garantir la qualité globale du produit, l'équipe Agile doit obtenir les commentaires des clients pour savoir si le produit répond aux attentes des clients. Cela doit être effectué à la fin de chaque itération, et le retour d'information sera une entrée pour les itérations suivantes.
Facteurs clés de succès
Dans les projets Agile, des produits de qualité peuvent être fournis si les tests Agile réussissent.
Les points suivants doivent être pris en compte pour le succès des tests Agile -
Les tests agiles sont basés sur des approches de test d'abord et de test continu. Par conséquent, les outils de test traditionnels, qui reposent sur l'approche du dernier test, peuvent ne pas convenir. Par conséquent, tout en choisissant les outils de test dans les projets Agile, l'alignement sur les tests Agile doit être vérifié.
Réduisez la durée totale des tests en automatisant les tests plus tôt dans le cycle de vie du développement.
Les testeurs agiles doivent maintenir leur rythme pour s'aligner sur le calendrier des versions de développement. Par conséquent, une planification, un suivi et une planification appropriés des activités de test doivent être effectués à la volée avec la qualité du produit comme objectif.
Les tests manuels représentent 80% des tests dans les projets. Par conséquent, les testeurs expérimentés doivent faire partie de l'équipe Agile.
La participation de ces testeurs experts tout au long du cycle de vie du développement permet à toute l'équipe de se concentrer sur un produit de qualité répondant aux attentes des clients.
Définition des user stories mettant l'accent sur le comportement produit attendu par les utilisateurs finaux.
Identifier les critères d'acceptation au niveau de la user story / au niveau de la tâche selon les attentes du client.
Estimation de l'effort et de la durée des activités de test.
Planification des activités de test.
S'aligner avec l'équipe de développement pour assurer la production de code qui répond aux exigences avec une conception de test initiale.
Testez d'abord et testez en continu pour vous assurer que le statut Terminé est atteint en répondant aux critères d'acceptation au moment prévu.
Assurer des tests à tous les niveaux du sprint.
Test de régression à la fin de chaque sprint.
Collecter et analyser les métriques de produits utiles à la réussite du projet.
Analyser les défauts pour identifier ceux qui doivent être corrigés dans le Sprint actuel et ceux qui peuvent être reportés aux Sprints suivants.
Se concentrer sur ce qui est important du point de vue du client.
Lisa Crispin a défini sept facteurs clés pour le succès des tests agiles -
Whole Team approach- Dans ce type d'approche, les développeurs forment les testeurs et les testeurs forment d'autres membres de l'équipe. Cela aide tout le monde à comprendre chaque tâche du projet, de sorte que la collaboration et la contribution bénéficieront au maximum. La collaboration des testeurs avec les clients est également un facteur important pour définir leurs attentes dès le début et traduire les critères d'acceptation en critères requis pour réussir le test.
Agile Testing Mindset - Les testeurs sont proactifs dans l'amélioration continue de la qualité et collaborent constamment avec le reste de l'équipe.
Automate Regression Testing- Conception pour la testabilité et le développement d'entraînement avec des tests. Commencez simplement et laissez l'équipe choisir les outils. Soyez prêt à donner des conseils.
Provide and Obtain Feedback- Comme il s'agit d'une valeur Agile fondamentale, toute l'équipe doit être ouverte aux commentaires. Comme les testeurs sont des fournisseurs de commentaires experts, ils doivent se concentrer sur les informations pertinentes et nécessaires. En retour, lors de l'obtention de commentaires, il convient de tenir compte des changements et des tests de cas de test.
Build a Foundation of Core Agile Practices - Se concentrer sur les tests parallèlement au codage, à l'intégration continue, aux environnements de test collaboratifs, au travail incrémental, à l'acceptation des changements, au maintien de la synergie.
Collaborate with Customers - Obtenir des exemples, comprendre et vérifier la correspondance des exigences avec le comportement du produit, mettre en place des critères d'acceptation, obtenir des commentaires.
Look at the Big Picture - Stimuler le développement avec des tests et des exemples destinés aux entreprises en utilisant des données de test du monde réel et en réfléchissant aux impacts sur d'autres domaines.
Dans ce chapitre, nous verrons quelques attributs importants du test Agile.
Avantages des tests agiles
Les avantages des tests Agile sont:
Satisfaction du client grâce à un produit rapide et continu entièrement testé et à la recherche de commentaires des clients.
Les clients, les développeurs et les testeurs interagissent en permanence les uns avec les autres, réduisant ainsi le temps de cycle.
Les testeurs agiles participent à la définition des exigences en apportant leur expertise de test pour se concentrer sur ce qui est réalisable.
Les testeurs agiles participent à l'estimation en évaluant l'effort et le temps de test.
Conception de test précoce reflétant les critères d'acceptation.
Exigences de test consolidées par toute l'équipe, évitant les inconvénients.
Focalisation constante sur la qualité du produit par toute l'équipe.
Définition de Done le statut reflétant la réussite des tests garantit que l'exigence est satisfaite.
Rétroaction continue sur les retards ou les blocages afin que la résolution puisse être faite immédiatement avec l'effort de toute l'équipe.
Des réponses rapides aux besoins changeants et y répondre rapidement.
Tests de régression basés sur l'intégration continue.
Aucun délai entre le développement et les tests. tester d'abord, des approches de test continu sont suivies.
Tests d'automatisation mis en œuvre tôt dans le cycle de vie du développement, réduisant ainsi le temps et les efforts de test.
Meilleures pratiques en matière de tests agiles
Suivez les meilleures pratiques ci-dessous -
Inclusion de testeurs ayant une expertise dans tous les types de tests à tous les niveaux.
Testeurs participant à la définition des exigences, collaborant avec les clients sur le comportement attendu du produit.
Les testeurs partagent leurs commentaires en permanence avec les développeurs et les clients.
Tester les premières approches et les tests continus pour s'aligner sur le travail de développement.
Suivi de l'état des tests et de la progression des tests rapidement et constamment en mettant l'accent sur la livraison de produits de qualité.
Test d'automatisation au début du cycle de vie du développement pour réduire le temps de cycle.
Pour effectuer des tests de régression, utilisez les tests d'automatisation comme un moyen efficace.
Défis des tests agiles
Les défis suivants existent dans les tests Agile -
Le fait de ne pas comprendre l'approche Agile et ses limites par l'entreprise et la direction peut conduire à des attentes irréalisables.
Agile suit l'approche de toute l'équipe, mais tout le monde ne connaît pas l'essentiel des pratiques de test. Il est conseillé aux testeurs de coacher les autres, mais dans un scénario réel, cela peut être impraticable avec des sprints (itérations) cadrés dans le temps.
L'approche Test First exige que les développeurs basent le codage sur les commentaires du testeur, mais dans des scénarios réels, les développeurs sont plus habitués à baser le codage sur les exigences provenant du client ou de l'entreprise.
La responsabilité du produit de qualité incombe à toute l'équipe Agile, mais dans les étapes initiales, les développeurs peuvent ne pas se concentrer sur la qualité car ils sont davantage en mode de mise en œuvre.
L'intégration continue nécessite des tests de régression qui nécessitent un effort considérable, même s'il doit être automatisé.
Les testeurs peuvent être adaptables aux changements avec l'état d'esprit Agile, mais il peut être impossible de viser à terminer pendant le Sprint.
L'automatisation précoce est conseillée afin de réduire l'effort et le temps de test manuel. Mais, dans le scénario réel, arriver aux tests qui peuvent être automatisés et les automatiser nécessite du temps et des efforts.
Directives de test Agile
Suivez les instructions suivantes lors de l'exécution des tests Agile.
Participez à la planification de la version pour identifier les activités de test requises et proposer la version initiale du plan de test.
Participez à la session d'estimation pour arriver à l'effort et à la durée des tests afin que les activités de test soient prises en compte dans les itérations.
Participez à la définition de User Story pour arriver à des cas de test d'acceptation.
Participez à chaque réunion de planification de sprint pour comprendre la portée et mettre à jour le plan de test.
Collaborez en permanence avec l'équipe de développement pendant le sprint pour faire des tests et du codage un succès au sein du sprint.
Participez aux réunions quotidiennes debout et communiquez les retards de test ou les blocages, le cas échéant, pour recevoir une résolution immédiate.
Suivez et signalez régulièrement l'état des tests, la progression des tests et la qualité des produits.
Soyez prêt à s'adapter aux changements, en répondant avec des modifications aux scénarios de test, aux données de test.
Participez à des rétrospectives de sprint pour comprendre et contribuer aux meilleures pratiques et leçons apprises.
Collaborez pour obtenir les commentaires des clients à chaque sprint.
Comme dans le cas des tests traditionnels, les tests agiles doivent également couvrir tous les niveaux de test.
- Test unitaire
- Test d'intégration
- Test du système
- Test d'acceptation des utilisateurs
Test unitaire
- Fait avec le codage, par le développeur
- Pris en charge par un testeur qui écrit des cas de test assurant une couverture de conception à 100%
- Les cas de test unitaires et les résultats des tests unitaires doivent être examinés
- Les défauts majeurs non résolus (selon la priorité et la gravité) ne sont pas laissés
- Tous les tests unitaires sont automatisés
Test d'intégration
- Fait avec l'intégration continue au fur et à mesure que les sprints progressent
- Fait à la fin une fois tous les sprints terminés
- Toutes les exigences fonctionnelles sont testées
- Toutes les interfaces entre les unités sont testées
- Tous les défauts sont signalés
- Les tests sont automatisés lorsque cela est possible
Test du système
- Fait à mesure que le développement progresse
- Les histoires, fonctionnalités et fonctions des utilisateurs sont testées
- Tests effectués dans l'environnement de production
- Des tests de qualité sont exécutés (performance, fiabilité, etc.)
- Les défauts sont signalés
- Les tests sont automatisés lorsque cela est possible
Test d'acceptation des utilisateurs
Fait à la fin de chaque Sprint et à la fin du projet
Fait par le client. Les commentaires sont pris par l'équipe
Les commentaires seront une entrée pour les sprints suivants
Les User Stories d'un Sprint sont pré-vérifiées pour être testables et sont avec des critères d'acceptation définis
Types de test
- Tests de composants (tests unitaires)
- Tests fonctionnels (tests User Stories)
- Tests non fonctionnels (performances, charge, stress, etc.)
- Tests d'acceptation
Les tests peuvent être entièrement manuels, entièrement automatisés, combinaison de manuels et automatisés ou manuels pris en charge par des outils.
Prise en charge de la programmation et des tests de produits critiques
Les tests peuvent être pour -
Supporting Development (Support Programming) - Les tests de programmation de support sont utilisés par les programmeurs.
Pour décider du code à écrire pour accomplir un certain comportement d'un système
Quels tests doivent être exécutés après le codage pour s'assurer que le nouveau code n'entrave pas le reste des comportements du système
Verification only (Critique Product) - Les tests de produits critiques sont utilisés pour découvrir les insuffisances du produit fini
Tests face aux entreprises et à la technologie
Pour décider des tests à effectuer quand, vous devez déterminer si un test est -
- Face aux affaires, ou
- Face à la technologie
Tests face aux entreprises
Un test est un test destiné aux entreprises s'il répond aux questions encadrées avec des mots du domaine commercial. Celles-ci sont comprises par les experts métiers et les intéresseraient afin que le comportement du système puisse être expliqué dans le scénario temps réel.
Tests face à la technologie
Un test est un test orienté vers la technologie s'il répond aux questions encadrées par des mots issus du domaine technologique. Les programmeurs comprennent ce qui doit être mis en œuvre sur la base des clarifications sur la technologie.
Ces deux aspects des types de test peuvent être visualisés à l'aide des quadrants de test Agile définis par Brian Marick.
Quadrants de test Agile
En combinant les deux aspects des types de test, les quadrants de test Agile suivants sont dérivés par Brian Marick -
Les quadrants de tests agiles fournissent une taxonomie utile pour aider les équipes à identifier, planifier et exécuter les tests nécessaires.
Quadrant Q1- Niveau de l'unité, face à la technologie et supporte les développeurs. Les tests unitaires appartiennent à ce quadrant. Ces tests peuvent être des tests automatisés.
Quadrant Q2- Au niveau du système, face à l'entreprise et comportement conforme du produit. Les tests fonctionnels appartiennent à ce quadrant. Ces tests sont soit manuels, soit automatisés.
Quadrant Q3- Niveau d'acceptation du système ou de l'utilisateur, orientation professionnelle et concentration sur des scénarios en temps réel. Les tests d'acceptation par l'utilisateur appartiennent à ce quadrant. Ces tests sont manuels.
Quadrant Q4- Niveau d'acceptation système ou opérationnel, technologie face à la technologie et mise au point sur les performances, la charge, le stress, la maintenabilité, les tests d'évolutivité. Des outils spéciaux peuvent être utilisés pour ces tests avec des tests d'automatisation.
En combinant ces derniers, les quadrants de test Agile qui reflètent What-Testing-When peut être visualisé comme suit -
Les défenseurs de Scrum Whole Team Approach, en ce sens que chaque membre de l'équipe doit participer à chaque activité du projet. L'équipe Scrum s'auto-organise et est responsable des livrables du projet. La prise de décision est laissée à l'équipe qui se traduit par des actions appropriées au bon moment sans aucun retard. Cette approche encourage également l'utilisation appropriée des talents de l'équipe au lieu de se limiter à une seule activité. Les testeurs participent également à toutes les activités de projet et de développement en apportant leur expertise dans les tests.
Toute l'équipe travaille ensemble sur la stratégie de test, la planification des tests, la spécification des tests, l'exécution des tests, l'évaluation des tests et le rapport des résultats des tests.
Création de user story collaborative
Les testeurs participent à la création de User Story. Les testeurs apportent leurs idées sur le comportement possible du système. Cela aide le client et / ou l'utilisateur final à comprendre le système dans l'environnement réel et à obtenir ainsi la clarté sur ce qu'ils veulent réellement comme résultat. Cela se traduit par un gel plus rapide des exigences et réduit également la probabilité de modifications ultérieures des exigences.
Les testeurs proposent également les critères d'acceptation pour chaque scénario convenu par le client.
Les testeurs contribuent à la création de user stories testables.
Planification des versions
La planification des versions est effectuée pour l'ensemble du projet. Cependant, le framework Scrum implique une prise de décision itérative car plus d'informations sont obtenues au cours de l'exécution des sprints. Par conséquent, la session de planification des versions au début du projet n'a pas besoin de produire un plan de version détaillé pour l'ensemble du projet. Il peut être mis à jour en permanence, à mesure que des informations pertinentes sont disponibles.
Chaque fin de sprint n'a pas besoin d'avoir une version. Une version peut être après un groupe de sprints. Le principal critère d'une version est de fournir une valeur commerciale au client. L'équipe décide de la durée du sprint avec la planification des versions comme entrée.
La planification de la version est la base de l'approche de test et du plan de test pour la publication. Les testeurs estiment l'effort de test et planifient les tests pour la version. Lorsque les plans de version changent, les testeurs doivent gérer les changements, obtenir une base de test adéquate en tenant compte du contexte de publication plus large. Les testeurs fournissent également l'effort de test requis à la fin de tous les sprints.
Planification de sprint
La planification de sprint est effectuée au début de chaque sprint. Le backlog de sprint est créé avec les user stories extraites du backlog de produit pour l'implémentation dans ce sprint particulier.
Les testeurs devraient -
- Déterminer la testabilité des user stories sélectionnées pour le sprint
- Créer des tests d'acceptation
- Définir les niveaux de test
- Identifier l'automatisation des tests
Les testeurs mettent à jour le plan de test avec les estimations de l'effort de test et des durées dans le sprint. Cela garantit la fourniture de temps pour les tests requis pendant les sprints temporisés et également la responsabilité de l'effort de test.
Analyse des tests
Lorsqu'un sprint commence, alors que les développeurs poursuivent l'analyse de l'histoire pour la conception et l'implémentation, les testeurs effectuent une analyse de test pour les histoires dans le backlog de sprint. Le testeur crée les cas de test requis - des tests manuels et automatisés.
Essai
Tous les membres de l'équipe Scrum doivent participer aux tests.
Les développeurs exécutent les tests unitaires au fur et à mesure qu'ils développent le code des user stories. Les tests unitaires sont créés à chaque sprint, avant l'écriture du code. Les cas de test unitaires sont dérivés de spécifications de conception de bas niveau.
Les testeurs exécutent des fonctionnalités fonctionnelles et non fonctionnelles des user stories.
Les testeurs encadrent les autres membres de l'équipe Scrum avec leur expertise dans les tests afin que toute l'équipe ait une responsabilité collective pour la qualité du produit.
À la fin du sprint, le client et / ou les utilisateurs finaux effectuent des tests d'acceptation des utilisateurs et fournissent des commentaires à l'équipe Scrum. Cela constitue une entrée pour le prochain sprint.
Les résultats des tests sont collectés et conservés.
Test d'automatisation
Les tests d'automatisation sont très importants dans les équipes Scrum. Les testeurs consacrent du temps à la création, à l'exécution, à la surveillance et à la maintenance des tests et des résultats automatisés. Comme des changements peuvent survenir à tout moment dans les projets Scrum, les testeurs doivent s'adapter aux tests des fonctionnalités modifiées ainsi qu'aux tests de régression impliqués. Les tests d'automatisation facilitent la gestion des efforts de test associés aux modifications. Des tests automatisés à tous les niveaux facilitent la réalisation d'une intégration continue. Les tests automatisés s'exécutent beaucoup plus rapidement que les tests manuels sans effort supplémentaire.
Les tests manuels se concentrent davantage sur les tests exploratoires, la vulnérabilité du produit, la prévision des défauts.
Automatisation des activités de test
L'automatisation des activités de test réduit le fardeau des travaux répétés et entraîne des économies de coûts. Automatiser
- Génération de données de test
- Chargement des données de test
- Générer le déploiement dans l'environnement de test
- Gestion de l'environnement de test
- Comparaison des sorties de données
Les tests de régression
Dans un sprint, les testeurs testent le code qui est nouveau / modifié dans ce sprint. Cependant, les testeurs doivent également s'assurer que le code développé et testé dans les sprints précédents fonctionne également avec le nouveau code. Par conséquent, les tests de régression ont une importance particulière en mêlée. Les tests de régression automatisés sont exécutés en intégration continue.
Gestion de la configuration
Un système de gestion de configuration qui utilise des frameworks de construction et de test automatisés est utilisé dans les projets Scrum. Cela permet d'exécuter des analyses statiques et des tests unitaires à plusieurs reprises à mesure que le nouveau code est archivé dans le système de gestion de la configuration. Il gère également l'intégration continue du nouveau code avec le système. Les tests de régression automatisés sont exécutés pendant l'intégration continue.
Les cas de test manuels, les tests automatisés, les données de test, les plans de test, la stratégie de test et les autres artefacts de test doivent être contrôlés en version et nécessitent des autorisations d'accès appropriées. Cela peut être accompli en conservant les artefacts de test dans le système de gestion de configuration.
Pratiques de tests agiles
Les testeurs d'une équipe Scrum peuvent suivre les pratiques Agile suivantes -
Pairing- Deux membres de l'équipe s'assoient ensemble et travaillent en collaboration. Les deux personnes peuvent être deux testeurs ou un testeur et un développeur.
Incremental Test Design - Les cas de test sont développés au fur et à mesure que les sprints progressent et que les histoires d'utilisateurs sont ajoutées.
Métriques agiles
Pendant le développement du logiciel, la collecte et l'analyse des mesures aident à améliorer le processus et à atteindre ainsi une meilleure productivité, des livrables de qualité et la satisfaction du client. Dans le développement basé sur Scrum, cela est possible et les testeurs doivent faire attention aux métriques dont ils ont besoin.
Plusieurs métriques sont suggérées pour le développement Scrum. Les paramètres significatifs sont -
Ratio of Successful Sprints - (Number of successful Sprints / Total number of Sprints) * 100. Un Sprint réussi est celui dans lequel l'équipe pourrait respecter son engagement.
Velocity- La vélocité d'une équipe est basée sur le nombre de Story Points qu'une équipe a gagnés au cours d'un sprint. Les Story Points sont la mesure des User Stories comptées lors de l'estimation.
Focus Factor - (Velocity / Team’s Work Capacity) / 100. Le facteur de focalisation est le pourcentage de l'effort de l'équipe qui aboutit à des histoires finies.
Estimation Accuracy - (Estimated effort / Actual effort) / 100. La précision de l'estimation est la capacité de l'équipe à estimer l'effort avec précision.
Sprint Burndown- Travail (en Story Points ou en heures) qui reste Vs. Travail qui doit rester idéalement (selon l'estimation).
Si c'est plus, cela signifie que l'équipe a effectué plus de travail qu'elle ne peut en faire.
Si c'est moins, cela signifie que l'équipe n'a pas estimé avec précision.
Defect Count- Nombre de défauts dans un Sprint. Le nombre de défauts est la quantité de défauts dans le logiciel par rapport à l'arriéré.
Severity of Defects- Les défauts peuvent être classés comme mineurs, majeurs et critiques selon leur gravité. Les testeurs peuvent définir la catégorisation.
Rétrospectives de sprint
Dans Sprint Retrospectives, tous les membres de l'équipe participeront. Ils partagent -
- Les choses qui se sont bien passées
- Metrics
- La portée des améliorations
- Actions à appliquer
Dans le test Agile, les méthodes de test couramment utilisées sont issues des pratiques traditionnelles et sont alignées sur le principe - Test Early. Les scénarios de test sont écrits avant l'écriture du code. L'accent est mis sur la prévention, la détection et l'élimination des défauts en exécutant les bons types de test au bon moment et au bon niveau.
Dans ce chapitre, vous comprendrez les méthodes -
- Développement piloté par les tests (TDD)
- Développement piloté par les tests d'acceptation (ATDD)
- Développement axé sur le comportement (BDD)
Développement piloté par les tests
Dans la méthode de développement piloté par les tests (TDD), le code est développé sur la base de l'approche Testfirst dirigée par des cas de test automatisés. Un cas de test est écrit en premier pour échouer, le code est développé sur cette base pour s'assurer que le test réussit. La méthode est répétée, le refactoring se fait par le développement du code.
TDD peut être compris à l'aide des étapes suivantes -
Step 1 - Ecrire un cas de test pour refléter le comportement attendu de la fonctionnalité du code qui doit être écrit.
Step 2- Exécutez le test. Le test échoue car le code n'est toujours pas développé.
Step 3 - Développer du code basé sur le cas de test.
Step 4- Relancez le test. Cette fois, le test doit réussir car la fonctionnalité est codée. Répétez les étapes (3) et (4) jusqu'à ce que le test réussisse.
Step 5 - Refactoriser le code.
Step 6 - Exécutez à nouveau le test pour vous assurer qu'il réussit.
Répéter Step 1 – Step 6ajouter des cas de test pour ajouter des fonctionnalités. Les tests ajoutés et les tests précédents sont exécutés à chaque fois pour garantir que le code s'exécute comme prévu. Pour accélérer ce processus, les tests sont automatisés.
Les tests peuvent être au niveau de l'unité, de l'intégration ou du système. Une communication constante entre les testeurs et les développeurs doit être assurée.
Développement piloté par les tests d'acceptation
Dans la méthode ATDD (Acceptance Test Driven Development), le code est développé sur la base de l'approche test-first dirigée par les cas de test d'acceptation. L'accent est mis sur les critères d'acceptation et les cas de test d'acceptation rédigés par les testeurs lors de la création de l'histoire utilisateur en collaboration avec le client, les utilisateurs finaux et les parties prenantes concernées.
Step 1 - Rédiger des cas de test d'acceptation ainsi que des user stories en collaboration avec le client et les utilisateurs.
Step 2 - Définir les critères d'acceptation associés.
Step 3 - Développer un code basé sur les tests d'acceptation et les critères d'acceptation.
Step 4 - Exécutez les tests d'acceptation pour vous assurer que le code s'exécute comme prévu.
Step 5- Automatisez les tests d'acceptation. RépéterStep 3 – Step 5 jusqu'à ce que toutes les user stories de l'itération soient implémentées.
Step 6 - Automatisez les tests de régression.
Step 7 - Exécutez les tests de régression automatisés pour assurer une régression continue.
Développement axé sur le comportement (BDD)
Le développement piloté par le comportement (BDD) est similaire au développement piloté par les tests (TDD), et l'accent est mis sur le test du code pour garantir le comportement attendu du système.
Dans BDD, un langage comme l'anglais est utilisé afin qu'il ait du sens pour les utilisateurs, les testeurs et les développeurs. Il assure -
- Communication continue entre les utilisateurs, testeurs et développeurs.
- Transparence sur ce qui est développé et testé.
Les techniques de test issues des tests traditionnels peuvent également être utilisées dans les tests Agile. En plus de ceux-ci, des techniques et des terminologies de test spécifiques Agile sont utilisées dans les projets Agile.
Base de test
Dans les projets agiles, le backlog produit remplace les documents de spécification des exigences. Le contenu du backlog produit est normalement des user stories. Les exigences non fonctionnelles sont également prises en compte dans les user stories. Ainsi, la base de test dans les projets Agile est la user story.
Pour garantir la qualité des tests, les éléments suivants peuvent également être considérés comme base de test -
- Expérience des itérations précédentes du même projet ou des projets antérieurs.
- Fonctions existantes, architecture, conception, code et caractéristiques de qualité du système.
- Données sur les défauts des projets actuels et passés.
- Commentaires des clients.
- Documentation utilisateur.
Définition de terminé
La Définition de Terminé (DoD) est le critère utilisé dans les projets Agile pour garantir l'achèvement d'une activité dans le backlog Sprint. Le DoD peut varier d'une équipe Scrum à l'autre, mais il doit être cohérent au sein d'une équipe.
DoD est une liste de contrôle des activités nécessaires qui assurent la mise en œuvre des fonctions et des fonctionnalités dans une user story avec les exigences non fonctionnelles qui font partie de la user story. Une user story atteint l'étape Terminé une fois que tous les éléments de la liste de contrôle DoD sont terminés. Un DoD est partagé dans toute l'équipe.
Un DoD typique pour une user story peut contenir -
- Critères d'acceptation testables détaillés
- Critères pour assurer la cohérence de la User Story avec les autres dans l'itération
- Critères spécifiques liés au produit
- Aspects du comportement fonctionnel
- Caractéristiques non fonctionnelles
- Interfaces
- Exigences relatives aux données de test
- Couverture de test
- Refactoring
- Exigences d'examen et d'approbation
En plus du DoD pour les User Stories, DoD est également requis -
- à chaque niveau de test
- pour chaque fonctionnalité
- pour chaque itération
- pour la libération
Informations de test
Un testeur doit disposer des informations de test suivantes -
- Histoires d'utilisateurs à tester
- Critères d'acceptation associés
- Interfaces système
- Environnement dans lequel le système est censé fonctionner
- Disponibilité des outils
- Couverture de test
- DoD
Dans les projets Agile, comme le test n'est pas une activité séquentielle et que les testeurs sont censés travailler en mode collaboratif, il est de la responsabilité du testeur de -
- Obtenez régulièrement les informations de test nécessaires.
- Identifiez les lacunes d'information qui affectent les tests.
- Résolvez les lacunes en collaboration avec les autres membres de l'équipe.
- Décidez quand un niveau de test est atteint.
- Assurer l'exécution des tests appropriés aux moments pertinents.
Conception de tests fonctionnels et non fonctionnels
Dans les projets Agile, les techniques de test traditionnelles peuvent être utilisées, mais l'accent est mis sur les tests précoces. Les cas de test doivent être en place avant le début de l'implémentation.
Pour la conception de tests fonctionnels, les testeurs et les développeurs peuvent utiliser les techniques traditionnelles de conception de tests Black Box telles que -
- Partitionnement d'équivalence
- Analyse de la valeur limite
- Tables de décision
- Transition d'état
- Arbre de classe
Pour la conception de tests non fonctionnels, étant donné que les exigences non fonctionnelles font également partie de chaque user story, les techniques de conception de test boîte noire ne peuvent être utilisées que pour concevoir les cas de test pertinents.
Essais exploratoires
Dans les projets Agile, le temps est souvent le facteur limitant pour l'analyse et la conception de tests. Dans de tels cas, les techniques de test exploratoire peuvent être combinées avec les techniques de test traditionnelles.
Les tests exploratoires (ET) sont définis comme l'apprentissage simultané, la conception de tests et l'exécution de tests. Dans les tests exploratoires, le testeur contrôle activement la conception des tests au fur et à mesure de leur exécution et utilise les informations obtenues lors des tests pour concevoir de nouveaux et meilleurs tests.
Les tests exploratoires sont pratiques pour s'adapter aux changements dans les projets Agile.
Tests basés sur les risques
Les tests basés sur les risques sont des tests basés sur le risque d'échec et atténuent les risques à l'aide de techniques de conception de tests.
Un risque de qualité du produit peut être défini comme un problème potentiel de qualité du produit. Les risques liés à la qualité des produits comprennent -
- Risques fonctionnels
- Risques de performance non fonctionnels
- Risques d'utilisabilité non fonctionnelle
Une analyse des risques doit être effectuée pour évaluer la probabilité (vraisemblance) et l'impact de chaque risque. Ensuite, les risques sont hiérarchisés -
- Les risques élevés nécessitent des tests approfondis
- Les risques faibles ne nécessitent que des tests cursifs
Les tests sont conçus à l'aide de techniques de test appropriées basées sur le niveau de risque et la caractéristique de risque de chaque risque. Des tests sont ensuite exécutés pour atténuer les risques.
Tests d'ajustement
Les tests d'ajustement sont des tests d'acceptation automatisés. Les outils Fit et FitNesse peuvent être utilisés pour automatiser les tests d'acceptation.
FIT utilise JUnit, mais étend la fonctionnalité de test. Les tableaux HTML sont utilisés pour afficher les cas de test. Fixture est une classe Java derrière la table HTML. L'appareil prend le contenu du tableau HTML et exécute les cas de test sur le projet en cours de test.
Le plan de test est préparé au moment de la planification de la version et est révisé à chaque planification de sprint. Le plan de test sert de guide au processus de test afin d'avoir une couverture de test complète.
Le contenu typique d'un plan de test est -
- Stratégie de test
- Environnement de test
- Couverture de test
- Portée des tests
- Effort de test et calendrier
- Outils de test
Dans les projets Agile, tous les membres de l'équipe sont responsables de la qualité du produit. Par conséquent, tout le monde participe également à la planification des tests.
La responsabilité d'un testeur est de fournir la direction nécessaire et d'encadrer le reste de l'équipe avec son expertise en test.
Histoires d'utilisateurs
Les User Stories ne testent pas en principe des produits de travail. Cependant, dans les projets Agile, les testeurs participent à la création des User Stories. Les testeurs rédigent des User Stories qui apportent de la valeur au client et couvrent différents comportements possibles du système.
Les testeurs s'assurent également que toutes les histoires d'utilisateurs sont testables et garantissent les critères d'acceptation.
Tests manuels et automatisés
Lors de la première exécution des tests, des tests manuels sont utilisés. Ils comprennent -
- Tests unitaires
- Tests d'intégration
- Tests fonctionnels
- Tests non fonctionnels
- Tests d'acceptation
Les tests sont ensuite automatisés pour les exécutions suivantes.
Dans Test Driven Development, Les tests unitaires sont écrits en premier pour échouer, le code est développé et testé pour garantir la réussite des tests.
Dans Acceptance Test Driven Development, Les tests d'acceptation sont écrits en premier pour échouer, le code est développé et testé pour garantir la réussite des tests.
Dans d'autres méthodes de développement, les testeurs collaborent avec le reste de l'équipe pour assurer la couverture des tests.
Dans tous les types de méthodes, l'intégration continue a lieu, qui comprend des tests d'intégration continue.
L'équipe peut décider quand et quels tests doivent être automatisés. Même si l'automatisation des tests nécessite des efforts et du temps, les tests automatisés qui en résultent réduisent considérablement l'effort et le temps de test répétitif pendant les itérations du projet Agile. Cela permet à son tour à l'équipe d'accorder plus d'attention aux autres activités requises, telles que les nouvelles histoires d'utilisateurs, les changements, etc.
Dans Scrum, les itérations sont limitées dans le temps. Par conséquent, si un test de User Story ne peut pas être terminé dans un Sprint particulier, le testeur peut signaler lors de la réunion quotidienne que la User Story ne peut pas atteindre le Statut Terminé dans ce Sprint et doit donc être conservée en attente du Sprint suivant.
Résultats de test
Comme la plupart des tests dans les projets Agile sont automatisés, les outils génèrent les journaux de résultats de test nécessaires. Les testeurs examinent les journaux des résultats des tests. Les résultats des tests doivent être conservés pour chaque sprint / version.
Un résumé de test peut également être préparé qui contient -
- Portée du test (ce qui a été testé et ce qui n'a pas été testé)
- Analyse des défauts avec analyse des causes profondes si possible
- État du test de régression après la correction des défauts
- Problèmes et résolution correspondante
- Problèmes en attente, le cas échéant
- Toute modification requise dans la stratégie de test
- Métriques de test
Rapports de mesures de test
Dans les projets Agile, les métriques de test incluent les éléments suivants pour chaque Sprint -
- Effort de test
- Exactitude de l'estimation du test
- Couverture de test
- Couverture de test automatisée
- Nbre de défauts
- Taux de défauts (nombre de défauts par point User Story)
- Gravité des défauts
- Il est temps de corriger un défaut dans le même sprint (il en coûte 24 fois plus cher pour corriger un bogue qui échappe au sprint actuel)
- Nombre de défauts corrigés dans le même sprint
- Achèvement des tests d'acceptation par le client dans le cadre du sprint
Revue de sprint et rapports rétrospectifs
Les testeurs contribuent également à la revue de sprint et aux rapports rétrospectifs. Le contenu typique est -
- Métriques de test
- Les journaux de résultats de test examinent les résultats
- Ce qui a bien fonctionné et ce qui peut être amélioré du point de vue du test
- Les meilleures pratiques
- Leçons apprises
- Issues
- Commentaires des clients
Les activités de test agile peuvent être gérées efficacement à l'aide des concepts Kanban. Les éléments suivants garantissent que les tests sont terminés à temps dans une itération / sprint et se concentrent ainsi sur la livraison d'un produit de qualité.
Les User Stories testables et dimensionnées efficacement aboutissent au développement et aux tests dans les délais spécifiés.
La limite WIP (Work-In-Progress) permet de se concentrer sur un nombre limité de user stories à la fois.
Le tableau Kanban qui représente visuellement le flux de travail permet de suivre les activités de test et les goulots d'étranglement, le cas échéant.
Le concept de collaboration en équipe Kanban permet de résoudre les goulots d'étranglement au fur et à mesure qu'ils sont identifiés, sans temps d'attente.
La préparation des cas de test à l'avance, la maintenance de la suite de tests au fur et à mesure que le développement progresse et l'obtention des commentaires des clients aident à éliminer les défauts au sein de l'itération / sprint.
La définition de Done (DoD) est dite Done-Done dans le sens où une histoire n'atteint un état d'achèvement qu'après que le test soit également terminé.
Activités de test dans le développement de produits
Dans le développement de produit, les versions peuvent être suivies avec le tableau Kanban. Les fonctionnalités d'une version particulière sont affectées au tableau Feature Kanban qui suit visuellement l'état de développement des fonctionnalités.
Les fonctionnalités d'une version sont divisées en histoires et développées dans la version en utilisant une approche agile.
Les activités de test Agile suivantes garantissent une livraison de qualité dans chaque version et à la fin de toutes les versions également -
Les testeurs participent à la création de User Story et s'assurent ainsi -
Tous les Comportements possibles du Système sont capturés au moyen des User Stories et des Exigences Non-fonctionnelles qui font partie des User Stories.
Les histoires d'utilisateurs peuvent être testées.
La taille des User Stories permet au développement et aux tests d'être terminés (DoneDone) dans l'itération.
Tableau Kanban des tâches visuelles -
Représente l'état et la progression des tâches
Les goulots d'étranglement sont identifiés immédiatement lorsqu'ils surviennent
Facilite la mesure du temps de cycle qui peut ensuite être optimisé
La collaboration d'équipe aide à -
Responsabilité de toute l'équipe pour un produit de qualité
Résolution des goulots d'étranglement au fur et à mesure de leur apparition, gain de temps d'attente
Contribution de chaque expertise dans toutes les activités
Intégration continue axée sur les tests d'intégration continue
Automatisation des tests pour économiser sur l'effort et le temps de test
Prévention des défauts avec des cas de test écrits plus tôt pour le développement et encadrement des développeurs sur ce qui est anticipé par différents comportements du système -
Limite WIP pour se concentrer sur un nombre limité d'histoires d'utilisateurs à la fois
Tests continus au fur et à mesure de l'avancement du développement, pour garantir la correction des défauts dans l'itération -
Assurer la couverture des tests
Gardez le nombre de défauts ouverts bas
Exploration de l'histoire
Exploration d'histoire est la communication au sein d'une équipe Agile pour explorer la compréhension de l'histoire lorsque le propriétaire du produit transmet une histoire pour acceptation pour le développement.
Le propriétaire du produit propose l'histoire en fonction de la fonctionnalité attendue par le système. Les développeurs explorent davantage chaque histoire avant de la marquer comme prête à être acceptée. Les testeurs participent également à la communication du point de vue des tests pour la rendre aussi testable que possible.
La finalisation de l'histoire est basée sur une communication constante et continue entre le Product Owner, les Développeurs et les Testeurs.
Estimation
L'estimation se produit dans la planification des versions et dans chaque planification des itérations.
Dans Release Planning, les testeurs fournissent -
- Informations sur les activités de test requises
- Estimation de l'effort pour le même
Dans la planification des itérations, les testeurs contribuent à décider quelles histoires et combien d'histoires peuvent être incluses dans une itération. La décision dépend de l'effort de test et de l'estimation du calendrier de test. L'estimation de l'histoire reflète également l'estimation du test.
Dans Kanban, Done-Done n'est accompli que lorsqu'une histoire est développée et testée et marquée comme complète sans défauts.
Par conséquent, l'estimation de test joue un rôle majeur dans l'estimation de l'histoire.
Planification de l'histoire
La planification de l'histoire commence après qu'une histoire a été estimée et affectée à l'itération actuelle.
La planification de l'histoire comprend les tâches de test suivantes -
- Préparer les données de test
- Prolonger les tests d'acceptation
- Exécuter des tests manuels
- Conduire des sessions de tests exploratoires
- Automatisez les tests d'intégration continue
En plus de ces tâches de test, d'autres tâches peuvent également être nécessaires, telles que -
- Test de performance
- Les tests de régression
- Mises à jour des tests d'intégration continue associés
Progression de l'histoire
Story Progression révèle des tests supplémentaires qui sont nécessaires, résultant d'une communication continue entre les développeurs et les testeurs. Dans les situations où les développeurs ont besoin de plus de clarté sur l'implémentation, les testeurs effectuent des tests exploratoires.
Le test continu est effectué pendant la progression de l'histoire et comprend le test d'intégration continue. Toute l'équipe participe aux activités de test.
Acceptation de l'histoire
L'acceptation de l'histoire se produit lorsque l'histoire atteint l'état Terminé-Terminé. c'est-à-dire que l'histoire est développée et testée et signalée comme terminée.
On dit que le test de l'histoire est terminé lorsque tous les tests pertinents pour l'histoire ou le niveau d'automatisation des tests sont satisfaits.
Dans les projets Agile, les testeurs sont responsables des tâches quotidiennes suivantes -
Soutenir les développeurs dans le codage, avec des clarifications sur le comportement attendu du système.
Aider les développeurs à créer des tests unitaires efficaces et efficients.
Développer des scripts d'automatisation.
Intégrez des outils / scripts de test d'automatisation avec une intégration continue pour les tests de régression.
Pour une mise en œuvre efficace et rapide de ces tâches, un système d'intégration continue (CI) qui prend en charge les CI de code et les composants de test est utilisé dans la plupart des projets Agile.
Les testeurs et les développeurs de projets agiles peuvent bénéficier de divers outils pour gérer les sessions de test et pour créer et soumettre des rapports d'anomalies. En plus des outils spécialisés pour les tests agiles, les équipes agiles peuvent également bénéficier d'outils d'automatisation et de gestion des tests.
Note - Les solutions d'automatisation d'enregistrement et de lecture, de dernier test, de poids lourd et de test ne sont pas agiles car -
Le flux de travail du dernier test encouragé par de tels outils ne fonctionne pas pour les équipes Agile.
Les scripts non maintenables créés avec de tels outils deviennent un obstacle au changement
Ces outils spécialisés créent un besoin de spécialistes de l'automatisation des tests et favorisent ainsi les silos
Les outils largement utilisés sont -
S.No. | Outil et objectif |
---|---|
1 | Hudson Cadre CI |
2 | Selenium Test fonctionnel - intégré à Hudson |
3 | CruiseControl Cadre CI |
4 | Junit Test unitaire Java |
5 | Nunit Test d'unité .Net |
6 | Cobertura / JavaCodeCoverage / JFeature / JCover / Couverture des tests Java |
sept | Jester Java - Test de mutation / amorçage automatique des erreurs |
8 | Gretel Outil de surveillance de la couverture des tests Java |
9 | TestCocoon C / C ++ ou C # - réduit la quantité de tests en trouvant des tests redondants et trouve du code mort |
dix | JAZZ Java - Branche, Node et Defuse Coverage et implémente une interface graphique, des planificateurs de test, une instrumentation dynamique et un analyseur de test |
11 | Ant Java - Construction d'automatisation |
12 | Nant .Net - Construction d'automatisation |
13 | Bonfire Module complémentaire Agile Testing pour JIRA |
Outils d'automatisation des tests agiles
Prise en charge des outils d'automatisation de test Agile efficaces -
Automatisation précoce des tests en utilisant une approche test-first.
Rédaction de code d'automatisation de test en utilisant des langages réels, des langages spécifiques au domaine.
Se concentrer sur le comportement attendu du système.
Séparer l'essence du test des détails de mise en œuvre, le rendant ainsi indépendant de la technologie.
Favoriser la collaboration.
Les tests unitaires automatisés (utilisant Junit ou NUnit) prennent en charge l'approche test-first pour le codage. Ce sont des tests en boîte blanche et garantissent que la conception est saine et qu'il n'y a aucun défaut. Ces tests sont élaborés par des développeurs avec le soutien de testeurs et peuvent être indépendants de la fonctionnalité requise. Cela se traduit par la livraison d'un produit qui peut ne pas répondre aux exigences des clients et donc sans valeur commerciale.
Ce problème est résolu par l'automatisation des tests d'acceptation qui sont écrits avec la collaboration du client, d'autres parties prenantes, des testeurs et des développeurs. Les tests d'acceptation automatisés sont rédigés par les clients ou les propriétaires de produits / analystes commerciaux reflétant le comportement attendu du produit. L'implication des développeurs assure la production de code selon les exigences. Cependant, si le test se concentre uniquement sur l'acceptation, le code résultant peut rester non extensible.
Ainsi, les tests unitaires automatisés et les tests d'acceptation automatisés sont complémentaires et tous deux sont nécessaires dans le développement Agile.
Les outils et cadres agiles qui prennent en charge les tests d'acceptation automatisés sont:
- Fit
- Fitnesse
- Concordion
- Ruby
- Cucumber
En forme
Ward Cunningham a développé l'outil Fit qui peut être utilisé pour l'automatisation des tests d'acceptation. L'ajustement permet -
Les clients ou les propriétaires de produits pour donner des exemples de comportement de produit à l'aide de Microsoft Word et Microsoft Excel
Les programmeurs peuvent facilement transformer ces exemples en tests automatisés.
Fit 1.1 prend en charge Java et .NET.
FitNesse
FitNesse est un wiki, qui est un style de serveur Web qui permet à tout visiteur d'effectuer des modifications, y compris la modification de pages existantes et la création de nouvelles pages. Un langage de balisage simple vous permet de créer facilement des en-têtes, de mettre du texte en gras, de souligner et d'italique, de créer des listes à puces et d'effectuer d'autres types de mise en forme simple.
Dans FitNesse, l'automatisation des tests d'acceptation est la suivante -
Exprimez les tests sous forme de tableaux de données d'entrée et de données de sortie attendues.
Utilisez FitNesse pour placer la table de test sur la page que vous pouvez modifier.
Vous pouvez également placer le tableau de test dans Microsoft Excel, copier dans le presse-papiers, puis utiliser le Spreadsheet to FitNesse commande pour que FitNesse formate votre tableau correctement
Lancer le test
Vous obtenez les résultats du test par codage couleur des cellules dans la table de test
les cellules vertes indiquent que les valeurs attendues sont obtenues
les globules rouges indiquent qu'une valeur différente de celle attendue est obtenue
les cellules jaunes indiquent qu'une exception a été levée
Concombre
Cucumber est un outil basé sur le framework BDD (Behavior Driven Development). Les principales caractéristiques sont -
Est utilisé pour écrire des tests d'acceptation pour les applications Web.
Permet l'automatisation de la validation fonctionnelle dans un format facilement lisible et compréhensible comme l'anglais simple.
A été implémenté dans Ruby puis étendu au framework Java. Les deux prennent en charge Junit.
Prend en charge d'autres langages comme Perl, PHP, Python, .Net, etc.
Peut être utilisé avec Selenium, Watir, Capybara, etc.