4. HITEMA – Groupama Gan Vie L’automatisation des tests fonctionnels SIMON Emeline 3 Introduction De nos jours, la robotisation est très présente dans l’industrie, ainsi que dans l’informatique. La robotisation des tests en informatique, c’est-à-dire le principe de réaliser les tests par un ordinateur est appelé l’automatisation des tests. La qualité est également très normée, telle que ISO 2000, et il est nécessaire de la contrôler. Lorsqu’une application est créée ou améliorée dans une entreprise, elle est soumise à différents types de tests. Ceux-ci permettent de vérifier le bon fonctionnement de ce qui a été développé et contrôler que la solution correspond à ce que le client a demandé. Je m’attarderai dans un premier temps sur les tests fonctionnels, tout d’abord en expliquant ce que sont les plans et cahier de tests (aussi appelés Recette) utilisés pour les réaliser. Ensuite je vous présenterai les différents outils de recettage qui existent et ceux utilisés dans mon propre domaine professionnel. Enfin, je répondrai à la question concernant la pertinence et la possibilité de l’automatisation totale des tests fonctionnels. Nous sommes en effet en droit de nous demander si les robots sont en mesure de réaliser le travail effectué par des humains aujourd’hui.
As demands for safety and mobility have grown and technological possibilities have multiplied, interest in automation has grown. Seeking to accelerate the development and introduction of fully automated vehicles and highways, the United States Congress authorized more than $650 million over six years for intelligent transport systems (ITS) and demonstration projects in the 1991 Intermodal Surface Transportation Efficiency Act (ISTEA). Congress legislated in ISTEA that "the Secretary of Transportation shall develop an automated highway and vehicle prototype from which future fully automated intelligent vehicle-highway systems can be developed. Such development shall include research in human factors to ensure the success of the man-machine relationship. The goal of this program is to have the first fully automated highway roadway or an automated test track in operation by 1997. This system shall accommodate installation of equipment in new and existing motor vehicles." [ISTEA 1991, part B, Section 6054(b)].
2. HITEMA – Groupama Gan Vie L’automatisation des tests fonctionnels SIMON Emeline 1 Table des matières Introduction............................................................................................................................................. 3 I. La phase de recette dans un projet................................................................................................. 4 A. Pourquoi et à quel moment réaliser des tests ? ......................................................................... 4 1) Les différentes méthodes de projet et les différents types de tests. ..................................... 4 2) Pourquoi réaliser des tests ? ................................................................................................... 7 3) A quel moment réaliser ces tests ? ......................................................................................... 7 B. La préparation de recette et les plannings.................................................................................. 8 1) Planning et plan de tests ......................................................................................................... 8 2) Jeux de données et base de données...................................................................................... 9 3) Le cahier de recette................................................................................................................. 9 C. L’exécution de recette et les suivis d’avancement. .................................................................. 10 II. Les outils de recettage................................................................................................................... 12 A. Les logiciels de tests sur PC ....................................................................................................... 12 1) Sélénium................................................................................................................................ 12 2) Quicktest Professional........................................................................................................... 12 3) QAWizard .............................................................................................................................. 13 B. Les logiciels de tests sur mobile ................................................................................................ 13 1) Des tests spécifiques aux mobiles......................................................................................... 13 2) Les outils à disposition : payants........................................................................................... 14 3) Les outils à disposition : gratuits ........................................................................................... 14 C. Les logiciels de suivi d’anomalie................................................................................................ 15 1) Un logiciel open source : MantisBT....................................................................................... 15 2) Des concurrents à MantisBT.................................................................................................. 16 III. Peut-on envisager une totale automatisation des tests ?......................................................... 17 A. Les avantages de l’automatisation............................................................................................ 17 B. Les inconvénients...................................................................................................................... 18 C. La reconnaissance des formes : les CAPTCHA........................................................................... 19 Conclusion ............................................................................................................................................. 21 Annexes................................................................................................................................................. 24

Industrial robotics is a sub-branch in the industrial automation that aids in various manufacturing processes. Such manufacturing processes include; machining, welding, painting, assembling and material handling to name a few.[85] Industrial robots utilizes various mechanical, electrical as well as software systems to allow for high precision, accuracy and speed that far exceeds any human performance. The birth of industrial robot came shortly after World War II as United States saw the need for a quicker way to produce industrial and consumer goods.[86] Servos, digital logic and solid state electronics allowed engineers to build better and faster systems and overtime these systems were improved and revised to the point where a single robot is capable of running 24 hours a day with little or no maintenance. In 1997, there were 700,000 industrial robots in use, the number has risen to 1.8M in 2017[87]
PhantomJS va nous servir de "Web-Driver" et cela sera là son unique utilité. De quoi s'agit-il ? Afin que Python puisse interagir avec le navigateur Web (Chrome, Firefox ou autres), de la même manière que la communication avec une base de données, il nous faut un driver (pilote). C'est là qu'intervient le Web Driver, il permet la communication entre le navigateur Web et notre script Python. De base, Selenium peut utiliser différents drivers pour différents navigateurs (Chrome, Firefox, Opéra) mais ce qui nous intéresse, ce n'est pas d'ouvrir un navigateur mais d'avoir un navigateur headless (sans interface graphique, uniquement en ligne de commandes). C'est là qu'intervient PhantomJS, qui fournit lui-même son Web Driver. L'utilité c'est donc la rapidité d'exécution par rapport aux navigateurs classiques.
Il s'agit de tester un module indépendamment du reste du programme afin de s'assurer qu'il répond aux spécifications fonctionnelles et qu'il fonctionne correctement en toutes circonstances. Cette vérification est essentielle, en particulier dans les applications critiques. Elle s'accompagne la plupart du temps d'une vérification de la globalité du code, qui consiste à s'assurer de la conformité de l'ensemble ou d’une fraction déterminée des instructions présentes dans le code à tester. L'ensemble des tests unitaires doit être rejoué après une modification du code afin de vérifier qu'il n'y a pas de régressions (l'apparition de nouveaux dysfonctionnements).
Ainsi, l'automatisation peut s'appliquer à des processus qui ne mettent en œuvre aucune énergie physique appréciable : détection ; contrôle et mesures ; calculs en temps réel, c'est-à-dire à mesure que le processus se déroule, en vue d'en assurer la conduite ; gestion en temps réel d'un processus en vue d'en contrôler strictement l'économie ; diagnostic ; reconnaissance des formes, c'est-à-dire identification à partir de multiples critères. L'automatisation peut atteindre divers degrés de complexité dont la classification a été établie.
I’ve used other automation tools besides VBA. Ubot and iMacros are both excellent, and powerful programs (their own programming languages, really). In some respects they’re easier, and for 99% of web automation tasksg, you really can’t go wrong with either. But I got to where I only used VBA because my programming was getting into Windows API’s and command line calls (Visual Basic is tightly integrated with Windows), plus I often found myself using Excel alongside these programs anyway. I discovered there’s almost nothing VBA can’t do with automating Windows and Internet Explorer (even making IE appear as a different browser), and it seemed to me investing time learning Microsoft’s Visual Basic programming language just made more sense.

5. HITEMA – Groupama Gan Vie L’automatisation des tests fonctionnels SIMON Emeline 4 I. La phase de recette dans un projet Dans cette première partie, nous allons tout d’abord comprendre la notion de projet et ce qu’elle représente. Au sein de celui-ci, il est nécessaire de réaliser des tests mais pas à n’importe quel moment. C’est pourquoi, après avoir détaillé le système de projet et l’importance des tests, je développerai l’étape de préparation de recette et des plannings. Enfin, je détaillerai l’étape suivante qui est l’exécution de recette et les suivis d’avancements réalisés pendant cette phase. A. Pourquoi et à quel moment réaliser des tests ? 1) Les différentes méthodes de projet et les différents types de tests. Il existe plusieurs méthodes de gestion de projet et chacune sans exception possède une phase de tests. Elles ont bien évidemment des avantages et des inconvénients. Ayant pour expérience de travail la méthode linéaire, je développerai la suite de mon mémoire en me basant sur cette méthode. La méthode linéaire (ou « cycle en V ») : Cette méthode est classique en gestion de projet : c’est une succession de phases permettant d’aboutir au résultat final. Chaque phase ne chevauche pas sur la précédente ou la suivante : 1 – Source : http://www.ice-tech.fr/fr/p/domaines-interventions Cette méthode est assez rigoureuse est nécessite une organisation précise. Ses avantages sont : - Normalisation des étapes de développement - Rédaction de spécification pour les développements mais aussi pour les tests - Les tests sont effectués dans un environnement stable


A noter, le langage utilisé pour développer les tests d’acceptance est volontairement simple dans le but de le rendre compréhensible et constructible par un non initié à la programmation. Avec un petit peu de formation, il est possible de décharger les développeurs de l’élaboration de ces tests pour les attribuer à une équipe de testeur dédié par exemple.
Pour nuancer, il est important de souligner que les tests automatisés ne peuvent pas remplacer les tests manuels. En effet, les tests automatisés permettent d’avoir une idée de la robustesse d’une application, mais elle ne peuvent pas permettre la découverte de tous les bogues d’un projet en développement. En ce sens, l’oeil humain est nécessaire afin de contrôler la qualité de l’application..

The food retail industry has started to apply automation to the ordering process; McDonald's has introduced touch screen ordering and payment systems in many of its restaurants, reducing the need for as many cashier employees.[64] The University of Texas at Austin has introduced fully automated cafe retail locations.[65] Some Cafes and restaurants have utilized mobile and tablet "apps" to make the ordering process more efficient by customers ordering and paying on their device.[66] Some restaurants have automated food delivery to customers tables using a Conveyor belt system. The use of robots is sometimes employed to replace waiting staff.[67]
De même, lié à des problèmes de gestionnaire de fenêtre, la gestion native du driver de Firefox (native events) n'est pas activée par défaut sur Linux. C'est donc la gestion "synthétique" qui est utilisée (synthetic events). À savoir l'injection de JavaScript. Ce qui empêche l'utilisation de l'API des interactions utilisateurs avancés (drag-N-drop & co) car elle est mal supportée avec les événements synthétiques. Et la maintenance de cette gestion native par le passé pour Firefox a introduit des régressions.
On peut se servir d’IFTTT pour booster sa visibilité sur le web en partageant instantanément un même statut sur Facebook, Twitter et Linkedin. Pour simplifier l’archivage de ses données numériques en enregistrant automatiquement les pièces jointes d’un e-mail dans sa Dropbox. Pour faire de la veille en demandant à recevoir une alerte dès qu’un site internet traite d’un sujet qui nous intéresse. Et puis, bien sûr, pour s’amuser en programmant l’heure d’allumage de la machine à café par exemple !
Zennoposter devient incroyablement puissant lorsque vous utilisez des logiciels, des outils et des comptes Web que vous possédez déjà. Il y a eu un énorme mouvement dans l’industrie du logiciel vers la programmation basée sur le Web et les développeurs Internet commencent à reconnaître le potentiel qu’il apporte à leurs applications. Les meilleurs outils de marketing Internet tels que Ahref, Majestic, Semrush et des dizaines d’autres sont entièrement basés sur le Web. Les logiciels bureautiques deviennent obsolètes en tout cas dans l’univers des marketing sur internet.
De même, lié à des problèmes de gestionnaire de fenêtre, la gestion native du driver de Firefox (native events) n'est pas activée par défaut sur Linux. C'est donc la gestion "synthétique" qui est utilisée (synthetic events). À savoir l'injection de JavaScript. Ce qui empêche l'utilisation de l'API des interactions utilisateurs avancés (drag-N-drop & co) car elle est mal supportée avec les événements synthétiques. Et la maintenance de cette gestion native par le passé pour Firefox a introduit des régressions.
Par la suite, vous serez plus à même de faire le bon choix. N’oubliez pas que ce ne sont pas vos méthodes qui devraient s’adapter à l’outil mais bien l’inverse, sauf si vous en êtes à vos premiers pas. Prenez le temps de questionner sur les mécanismes de licences, les modules dont vous avez réellement besoin et ceux qui pourraient s’ajouter par la suite.

Pour nuancer, il est important de souligner que les tests automatisés ne peuvent pas remplacer les tests manuels. En effet, les tests automatisés permettent d’avoir une idée de la robustesse d’une application, mais elle ne peuvent pas permettre la découverte de tous les bogues d’un projet en développement. En ce sens, l’oeil humain est nécessaire afin de contrôler la qualité de l’application..
Gratuit et orienté purement vers les applicatifs sur le net, l’automate de test Selenium permet de travailler sur les langages les plus répandus pour la programmation web tels que C#, JAVA, Perl, PHP, Python ou Ruby. Sa simplicité d’utilisation pour l’enregistrement de tests et son efficacité pour les tests multinavigateurs font de lui un outil ultra productif pour automatiser les tests. Aujourd’hui, les principaux éditeurs de navigation web l’intègrent de façon native afin de faciliter les tests sur leurs platesformes. 

Nous avons pris soin d'importer le framework unittest de Python afin de disposer de la classe TestCase et du test runner. Nous avons également importé le webdriver fourni par Selenium, qui va nous permettre d'automatiser le navigateur. Les méthodes setUp() et tearDown() d'xUnit sont implémentées pour initialiser notre driver avant de lancer les tests et le fermer une fois terminé.

Each time you press F8 the line of code highlighted in yellow will execute, and then the next line down of code will turn yellow and wait for your key press. Say you change the code in a line and want to re-run it… you’d move the yellow line back up by dragging the yellow arrow with your mouse, or by clicking the line you want and then pressing CTRL+F9
PhantomJS va nous servir de "Web-Driver" et cela sera là son unique utilité. De quoi s'agit-il ? Afin que Python puisse interagir avec le navigateur Web (Chrome, Firefox ou autres), de la même manière que la communication avec une base de données, il nous faut un driver (pilote). C'est là qu'intervient le Web Driver, il permet la communication entre le navigateur Web et notre script Python. De base, Selenium peut utiliser différents drivers pour différents navigateurs (Chrome, Firefox, Opéra) mais ce qui nous intéresse, ce n'est pas d'ouvrir un navigateur mais d'avoir un navigateur headless (sans interface graphique, uniquement en ligne de commandes). C'est là qu'intervient PhantomJS, qui fournit lui-même son Web Driver. L'utilité c'est donc la rapidité d'exécution par rapport aux navigateurs classiques.
×