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
The introduction of prime movers, or self-driven machines advanced grain mills, furnaces, boilers, and the steam engine created a new requirement for automatic control systems including temperature regulators (invented in 1624 (see Cornelius Drebbel)), pressure regulators (1681), float regulators (1700) and speed control devices. Another control mechanism was used to tent the sails of windmills. It was patented by Edmund Lee in 1745.[16] Also in 1745, Jacques de Vaucanson invented the first automated loom. The design of feedback control systems up through the Industrial Revolution was by trial-and-error, together with a great deal of engineering intuition. Thus, it was more of an art than a science. In the mid-19th century mathematics was first used to analyze the stability of feedback control systems. Since mathematics is the formal language of automatic control theory, we could call the period before this time the prehistory of control theory.
Une caractéristique de l'automatisation moderne est qu'elle n'a pas toujours pour but d'assurer directement la commande des processus mais parfois seulement d'apporter une aide à la décision. C'est le rôle de ce que l'on appelle les systèmes d'intelligence artificielle qui, s'ils ont une vocation spécifique, sont nommés systèmes experts. Ces systèmes d'intelligence artificielle se répandent [...]
Une fois un scénario de test enregistré, il est possible de l’exporter dans plusieurs langages de programmation. Le langage PHP n’est pas intégré par défaut, il faut installer un second plugin pour pouvoir en bénéficier, disponible sur : https://addons.mozilla.org/fr/firefox/addon/selenium-ide-php-formatters/ Le code exporté sera au format PHPUnit. De fait, l’outil de tests unitaire et d'intégration PHPUnit sera capable de prendre en charge les scripts de tests générés par Selenium IDE. De même, Codeception qui est basé sur PHPUnit, devrait aussi prendre en charge ces tests. De cette façon, les testeurs n’ont pas à se soucier du code pour créer des scripts de tests fonctionnels et les développeurs peuvent intégrer ces tests à leur environnement PHPUnit. Néanmoins, ce deuxième plugin n’est plus maintenu depuis quelque temps, ce qui rend son utilisation compliqué.

PhantomJS est un navigateur sans interface graphique utilisé pour automatiser des interactions avec des pages web. PhantomJS intègre entre autre la navigation automatisée, la capture d'écran, les comportements utilisateurs. Il permet donc de faire des tests fonctionnels. L’environnement de navigation reproduit par PhantomJS est similaire à Safari ou à Google Chrome.


Afin de garantir, à chaque itération, la livraison d’une version conforme en terme de qualité aux exigences du client, l’intégration des tests dans le processus de construction du logiciel doit se faire dès le démarrage du projet, et tout au long de sa réalisation: c’est le principe du test continu, qui s’appuie sur l’automatisation des tests, rendue indispensable par la nécessité de répéter un nombre de tests important à chaque nouvelle itération du logiciel.
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).
13. HITEMA – Groupama Gan Vie L’automatisation des tests fonctionnels SIMON Emeline 12 II. Les outils de recettage Afin de réaliser la phase de recette, il faut bien évidemment s’appuyer sur des outils de tests. Il est possible – et c’est ce qui est pratiqué dans mon service – d’utiliser simplement le logiciel Excel pour réaliser les cahiers de recette. Cela permet d’effectuer les tests à la main. Cependant, il existe des outils adaptés à la réalisation de tests automatisés. A. Les logiciels de tests sur PC Il existe des logiciels pour effectuer des tests fonctionnels automatisés ; Ceux-ci se choisissent principalement en fonction du langage de programmation utilisé par l’application à tester, ainsi que par sa complexité, l’objectif à atteindre et le coût. 1) Sélénium Sélénium est un outil très utilisé pour automatiser les tests fonctionnels. [Annexe 4] Même s’il semble un peu compliqué d’apparence il est en réalité logique d’utilisation. Sélénium se décompose comme suit :  Selenium IDE : c'est une extension de Firefox, qui permet d'enregistrer une suite d'actions, qu'il sera possible de rejouer à volonté ;  Selenium Web Driver : il s'agit cette fois d'une API, disponible pour plusieurs langages, permettant de programmer des actions sur l'interface, et à vérifier les réponses. Les actions à réaliser peuvent être exportées depuis Selenium IDE. 2) Quicktest Professional QTPro, de HP, représente ce jour l’offre phare dans le monde professionnel. Le référentiel d’objets est particulièrement bien conçu, celui-ci pouvant notamment être généré lors de l’enregistrement, enrichi manuellement ou encore importé à partir d’un autre scénario. Paradoxalement, le produit souffre principalement de sa complétude, difficile à prendre en main pour un débutant. De plus, le coût de la licence est assez élevé par rapport aux autres offres du marché.

Home automation (also called domotics) designates an emerging practice of increased automation of household appliances and features in residential dwellings, particularly through electronic means that allow for things impracticable, overly expensive or simply not possible in recent past decades. The rise in the usage of home automation solutions has taken a turn reflecting the increased dependency of people on such automation solutions. However, the increased comfort that gets added through these automation solutions is remarkable.[77]
Alors oui, on peut considérer qu’utiliser plusieurs niveaux de tests est une opération répétitive dans le sens ou plusieurs intervenants vont devoir tester plusieurs fois le projet avec des méthodologies différentes. Néanmoins, ce n’est pas redondant car la recherche d’anomalie est beaucoup plus efficace et permet de détecter des instabilités liés à des mécanismes différents.
La première des étapes afin de pouvoir automatiser votre navigateur Web est l'installation de l'ennvironnement Python. Pour cela, rendez-vous sur le site https://www.python.org/downloads/ Deux versions seront au choix : la 3.5.2 et la 2.7.12. Celle qui sera utilisée dans l'exemple en dernière partie sera la version 3.5.2 (la plus récente donc). Une fois le téléchargement fini, procéder à l'installation qui prendra quelques temps en n'oubliant pas de cocher l'option au préalable "Add Python x.x TO PATH" (très important afin que l'interpréteur Python soit disponible dans une variable d'environnement). Dans le cas d'un système d'exploitation Windows, je conseille fortement d'installer Python à la racine de votre disque dur (C:/Python...). Sous MAC OS X, un simple "brew install Python" vous permettra d'installer l'environnement Python.
Les essais logiciels sont de plus en plus longs et complexes, les délais de plus en plus courts et les impacts d’une anomalie critiques. Les technologies de l’information sont partout, la qualité doit y être aussi. Cette présentation traite des bonnes pratiques à implémenter afin de réduire et d’éliminer ces enjeux présents dans vos processus d’entreprise. Vous en saurez plus sur l’importance d’automatiser, les défis du passage du manuel à l’automatisation et pourquoi les outils actuels n’offrent pas le ROI escompté. Une nouvelle démarche pour simplifier l’adoption et assurer le ROI est aussi présentée.
12. HITEMA – Groupama Gan Vie L’automatisation des tests fonctionnels SIMON Emeline 11 Il est possible de différencier les thèmes à recetter sur une application, notamment quand plusieurs collaborateurs sont en charge de la recette. Ainsi il est assez facile de séparer l’IHM1 , des requêtes sur la base de données ou encore des appels aux web services… Au cours de la recette, la MOA se doit d’être informée au mieux de la situation. Elle est très souvent sollicitée par les différents acteurs pour connaitre l’état de l’avancement, ce qui est terminé, ce qui est validé ou non, etc… Ainsi, pour être en mesure de répondre au mieux, la MOA réalise un suivi d’avancement de la recette. C’est un principe très précis et qui ne doit pas être fait « approximativement ». Pour chaque scénario existant, il existe plusieurs états que l’on peut définir comme suit : - RAF : reste à faire, le scénario n’a pas encore été testé - KO : scénario exécuté et non valide (une fiche d’anomalie lui est associé) - OK : scénario exécuté et validé - NT/Abandon : scénario abandonné car non testable Ces états permettent de réaliser une synthèse sur la totalité des scénarios. Il est alors possible de suivre quotidiennement l’avancement sur un thème en particulier ou sur la globalité. De multiples calculs et tableaux croisés peuvent être générés pour répondre aux différentes questions des acteurs, mais aussi pour gérer au mieux le temps et les ressources. [Annexe 2] En effet, le nombre total de test à réaliser au cours de la recette a été défini lors de la préparation de recette. Le nombre total a ensuite été divisé par le nombre de jours/semaines disponible afin d’obtenir une courbe idéale. Celle-ci permet d’avoir un point d’accroche et de suivi pour les différents chefs de projets. Cela a pour but d’éviter des retards sur le déroulement : on fait apparaitre sur le graphique les courbes de tests validés et les tests réalisés. [Annexe 3] 1 Interface Homme Machine
Based on a formula by Gilles Saint-Paul, an economist at Toulouse 1 University, the demand for unskilled human capital declines at a slower rate than the demand for skilled human capital increases.[100] In the long run and for society as a whole it has led to cheaper products, lower average work hours, and new industries forming (i.e., robotics industries, computer industries, design industries). These new industries provide many high salary skill based jobs to the economy. By 2030, between 3 and 14 percent of the global workforce will be forced to switch job categories due to automation eliminating jobs in an entire sector. While the number of jobs lost to automation are often offset by jobs gained from technological advances, the same type of job lost is not the same one replaced and that leading to increasing unemployment in the lower-middle class. This occurs largely in the US and developed countries where technological advances contribute to higher demand for high skilled labor but demand for middle wage labor continues to fall. Economists call this trend “income polarization” where unskilled labor wages are driven down and skilled labor is driven up and it is predicted to continue in developed economies.[101]
Increased automation can often cause workers to feel anxious about losing their jobs as technology renders their skills or experience unnecessary. Early in the Industrial Revolution, when inventions like the steam engine were making some job categories expendable, workers forcefully resisted these changes. Luddites, for instance, were English textile workers who protested the introduction of weaving machines by destroying them.[46] Similar movements have sprung up periodically ever since. For most of the nineteenth and twentieth centuries, the most influential of these movements were led by organized labor, which advocated for the retraining of workers whose jobs were rendered redundant by machines.
Likewise, a Feedback Control System is a system which tends to maintain a prescribed relationship of one system variable to another by comparing functions of these variables and using the difference as a means of control.[6] The advanced type of automation that revolutionized manufacturing, aircraft, communications and other industries, is feedback control, which is usually continuous and involves taking measurements using a sensor and making calculated adjustments to keep the measured variable within a set range.[7][8] The theoretical basis of closed loop automation is control theory.
Si vous êtes adepte des langages de programmation PHP ou C#, ZennoPoster a aussi quelque chose en réserve pour vous. Ce logiciel a conçu différents modules pour contrôler le navigateur selon vos préférences. Par exemple, si vous souhaitez utiliser votre propre code, vous n'avez pas besoin d'utiliser le modèle parce que vous pouvez créer votre propre programme - en contrôlant entièrement le navigateur. C'est vraiment pratique et polyvalent ! Vous pouvez utiliser ce logiciel à votre avantage en utilisant toutes ces langues tout en étant capable de gérer votre navigateur virtuellement en même temps.
Enfin, on finit par prendre un screenshot de la page pour vérifier que nous sommes bien connectés (le screenshot sera dans le même dossier que le script python de la macro), on retourne l'URL active de la page avec la méthode driver.current_url et on quitte avec la méthode .quit(). Il ne nous reste plus qu'à lancer notre script ! Pour cela ouvrez votre terminal/invite de commandes et taper "python macro.py" et votre macro va s'exécuter (pensez à autoriser le pare-feu à PhantomJS). Voilà notre script s'est bien exécuté et le tout assez rapidement.
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.
×