Après notre session des TechDays 2012 : MS TechDays 2012 - Mise en place d'une usine logicielle avec TFS et Test Manager 2010, et suite aux questions de fin de séance, nous avons eu l’idée de collecter les différentes « bonnes » pratiques ainsi que les trucs et astuces au sein de notre équipe de test.
Merci à Jean Dieu (QA Manager) et Marc Huhardeaux qui sont les auteurs des conseils ci-dessous
Recommandations générales
Stratégie des tests
Dans le Test Manager, séparez les tests de bases des tests fonctionnels.
Tests de base
Les tests de base regroupent :
Les tests de base regroupent :
- Tous les ‘clics’ possible sur un écran de l’application
- Chasser toutes les erreurs de type « erreur 404, 403, … »
Ce qui revient à parcourir l’ensemble des écrans de l’application. Ainsi nous sommes sur que l’utilisateur final n’aura pas d’écran non désiré (écran d’erreurs, mauvais écran,…)
Tests fonctionnels
Les tests fonctionnels regroupent
Les tests fonctionnels regroupent
- Tous les points fonctionnels décris par la maitrise d’ouvrage
- Valider le comportement correct de chaque point
Conclusion
Ce qui revient à valider l’ensemble des comportements et le résultat obtenu.
Cette stratégie possède un avantage certain, les tests de base peuvent être intégrés dans le Build, car nous considérons que l’apparition d’un écran d’erreur ou d’un écran non désiré est inacceptable pour le client/utilisateur final.
Alors il restera ensuite que les tests fonctionnels à passer.
Pratiques
Ce qui revient à valider l’ensemble des comportements et le résultat obtenu.
Cette stratégie possède un avantage certain, les tests de base peuvent être intégrés dans le Build, car nous considérons que l’apparition d’un écran d’erreur ou d’un écran non désiré est inacceptable pour le client/utilisateur final.
Alors il restera ensuite que les tests fonctionnels à passer.
Pratiques
- Faire un découpage au maximum des actions. Ainsi les méthodes générées sont réutilisable par la suite.
- Construire une base de données pour les jeux de test
- Exiger de la part des développeurs des Identifiant Unique à chaque élément cliquable de l’application
- Si l’application change de forme -> Pas de codage à refaire
- On est sûr de tester le bon élément
- Déclarer comme Bug, tout élément cliquable sans identifiant
- RIEN NE DOIT LAISSER INDIFFÉRENT ! Une faute d’orthographe, un mauvais alignement ou un comportement erratique…
- Avant de commencer les phases de tests il est préférable d’installer Visual Studio 2010 feature pack 2, ce qui permettra d’apporter plus d’options pour les phases de test.
- Ce pack permettra de pouvoir modifier avec facilité les noms des méthodes déjà enregistré.
- De pouvoir les supprimer
- De pouvoir déplacer les méthodes vers le fichier Uimap.cs afin de pouvoir coder à l’intérieur de ses méthodes, car dans certains le codage et obligatoire lorsque l’on veut effectuer certains cas de test.
Us et coutumes
Le piège est donc de rester enfermé dans ses habitudes d’internautes et de se contenter du rendu d’un seul navigateur. Avec 2 moniteurs différents il est possible d’ouvrir sur chacun une session avec un navigateur différent, et de tester alternativement sur l’un puis sur l’autre ce qui permet en plus de rester bien mieux conscient de ce que l’on fait
Le piège est donc de rester enfermé dans ses habitudes d’internautes et de se contenter du rendu d’un seul navigateur. Avec 2 moniteurs différents il est possible d’ouvrir sur chacun une session avec un navigateur différent, et de tester alternativement sur l’un puis sur l’autre ce qui permet en plus de rester bien mieux conscient de ce que l’on fait
Découverte d’un BUG
Le piège est de ne pas anticiper sur la correction d’un bug même mineur et de ne pas être assez explicite sur ce que j’attendais dans la correction.
Le piège est de ne pas anticiper sur la correction d’un bug même mineur et de ne pas être assez explicite sur ce que j’attendais dans la correction.
Exemple : on repère un indicateur oublié et on le signale. Se contenter de signaler une erreur sans donner une ébauche de solution ou de comportement complet attendu n’est pas suffisant, car la correction du BUG peut très bien (fréquent) ne pas répondre à 100% à ce qu’on désire, ainsi cela induit une perte de temps
Spécifications
Le piège est de traiter à la légère les éventuelles spécifications de développement. S’il est écrit que tel ou tel chose doit être faite, même en dépit du bon sens, il faut s’assurer ensuite que cela a été fait.
Nous ne sommes pas les utilisateurs finaux du produit, et peut-être que cette fonctionnalité inutile pour nous ne l’est pas pour l’utilisateur. Et en cas de doute, il ne faut jamais hésiter à déranger ceux qui ont la réponse : c’est pour eux que l’on travaille.
Le piège est de traiter à la légère les éventuelles spécifications de développement. S’il est écrit que tel ou tel chose doit être faite, même en dépit du bon sens, il faut s’assurer ensuite que cela a été fait.
Nous ne sommes pas les utilisateurs finaux du produit, et peut-être que cette fonctionnalité inutile pour nous ne l’est pas pour l’utilisateur. Et en cas de doute, il ne faut jamais hésiter à déranger ceux qui ont la réponse : c’est pour eux que l’on travaille.
Pour automatiser un test sur le calendrier
- Enregistrer l’ensemble des actions nécessaires sur le JQuery dans une seule capture.
- Copier cet enregistrement dans le fichier de classe partiel UIMap.cs
- Modifier la méthode pour qu’elle fasse ce que vous souhaitez.
- Appeler cette nouvelle méthode pour effectuer les actions.
Gestion des décalages d’une semaine (en positif et négatif).
- Mis en arguments de « ma fonction »
- un élément date (sous forme de string)
- un booléen disant si j’effectue un décalage ou un retour en arrière
- un entier indiquant le nombre de jours (valeur par défaut fixée à 7).
- Dans les modifications de la fonction,
- Vérifier s’il s’agit d’un changement
- Ensuite Vérifie qu’il n’y a pas eu de changement de mois (Important).
- De la nouvelle date, on récupère le numéro du jour qui nous servira pour déclencher l’action correspondante.
En affinant la partie gestion de la date, il est possible d’affiner encore plus le changement de date.
Astuce pour les éléments JQuery
L’enregistrement d’actions sur des éléments JQuery peut se faire de deux manières
- d’un seul tenant
- action par action indépendante
Préférez la solution 2 car en choisissant d’enregistrer chaque action de manière indépendante dans un enregistrement voici les avantages :
- La forte ré-utilisabilité
- Le déroulement de l’ensemble des actions concernées est plus rapide que pour l’enregistrement d’un seul tenant.
Convention de nommage
Cet aspect représente un point central pour le bon déroulement lors de la phase de création de test. Pensez avant même de commencer à votre convention de nommage, car le découpage va vite générer beaucoup de méthode
Il est préférable d’avoir un nom à rallonge qu’un nom peu explicite, il est plus aisé de comprendre « une phrase ». Car au moment de passer dans le Test Manager, lors de la création du plan, on s’y retrouve facilement.
Exemple : on a 2 pages web : Accueil et Login.
Nous avons codé l’action « transition » entre la page « Accueil » et « Login ». Cette méthode (généré par Visual Studio) est nommée : TransitionPageAccueilVersPageLogin
Nous mettrons cette rubrique Tips à jour régulièrement