9. HITEMA – Groupama Gan Vie L’automatisation des tests fonctionnels SIMON Emeline 8 En fonction de la méthode utilisée, ce sont deux chronologies qui apparaissent : 3 - Source : http://fr.slideshare.net/JUGLausanne/initiation-aux-tests-fonctionnels-philippe-kernevez- october-2009 Avant d’effectuer ces tests, l’étape primordiale est la préparation de recette. B. La préparation de recette et les plannings 1) Planning et plan de tests Comme décrit ci-dessus, la recette nécessite une préparation ainsi qu’un suivi complet. C’est pourquoi il est nécessaire avant de commencer la recette, de réaliser des plannings. C’est en planifiant des réunions MOA – MOE qu’il est possible de déterminer la charge de travail nécessaire. En effet, la MOE étant responsable du développement, elle est en capacité de donner des dates butoirs à la MOA. Ces dates constituent les différentes livraisons des composants de l’application. Cela peut être une fonctionnalité ou bien une interface. Quoiqu’il en soit, ces dates de livraison permettent à la MOA d’organiser les différentes phases de recette et surtout l’enchainement logique. C’est ce qui s’appelle un plan de tests : ce plan est constitué du planning mais aussi de la trame logique à suivre. Pour chaque période est associée un module à tester et une ou plusieurs ressources. [Annexe 1] Il possible de chevaucher les développements avec la recette lorsque le temps est précieux et non suffisant. Dans ce cas, la Moa effectue les tests fonctionnels sur les modules livrés par la MOE. Cependant, cela peut engendrer quelques problèmes de fonctionnement de l’application car certaines interfaces / fonctionnalités nécessitent d’autres modules qui ne sont pas encore livrés. Cela engendre du travail inutile de tests.
10. HITEMA – Groupama Gan Vie L’automatisation des tests fonctionnels SIMON Emeline 9 Cette opération de préparation de planning pré-recette, permet de donner une date de fin de recette aux responsables. Parfois – et c’est le cas chez Groupama gan vie – la phase de recette est suivi d’une phase d’homologation. Cette phase se présente comme une phase de recette mais de façon bien plus synthétique : c’est la phase de pré-production. Il faut donc également prévoir dans les plannings cette phase ainsi que les réunions adéquates. La Moa se chargeant de la recette, c’est bien souvent des référents métiers qui se chargent de l’homologation. Ceux sont eux qui décident si oui ou non il est possible de mettre en production. Ce n’est en aucun cas la MOA qui donne le GO pour la mise en production. Le planning est donc un élément indispensable dans un projet pour toutes les ressources de celui-ci. 2) Jeux de données et base de données Qu’elle soit manuelle ou automatisée, la recette fonctionnelle nécessite dans tous les cas des données. Celles-ci sont utilisées pour effectuer des tests. Cela peut être des noms, des numéros de téléphone, des adresses…. Toutes ces informations doivent être préparées afin de ne pas perdre de temps durant la phase de test. Si une ou plusieurs informations venaient à manquer durant le cycle de recette, cela ralentirait le processus : il faut chercher les informations, les préparer et ré-exécuter les tests. C’est pourquoi il est idéal de fabriquer un fichier référence regroupant l’ensemble des données qui seront utilisées : - Pour une recette manuelle, les testeurs s’appuieront sur ce fichier pour préparer le cahier de test et si besoin pendant les tests en complément. - Pour une recette automatisée, c’est le logiciel utilisé qui aura pour point d’appui ce fichier. Il s’alimentera avec les informations contenues dans ce fichier, en fonction des paramètres fournis par les testeurs. De même, la phase de préparation nécessite avant tout une base de données pour les tests. Il faut donc créer la base en fonction des spécifications si elle n’existe pas. Dans le cas d’évolution sur une application existante, il faut s’assurer que la base a bien été modifiée en conséquence. Celle-ci doit également être soumise aux tests. 3) Le cahier de recette Avant de démarrer l’exécution de la recette – celle-ci ne se fait pas « à l’aveugle » - il faut rédiger un cahier de recette. J’ai eu l’occasion dans mon travail de rédiger plusieurs cahiers de tests et donc d’apprendre à le faire. En effet, ceux-ci se préparent en suivant les spécifications fonctionnelles rédigées après l’expression de besoin. Les spécifications fonctionnelles (détaillées ou générales) décrivent le fonctionnement de l’application, de ses modules ainsi que de ses interfaces. Elles répertorient alors la totalité des attentes du client détaillées sous formes de points à traiter. Le travail à réaliser est alors de prendre un à un les points énoncés et de préparer des scénarios de test. Un scénario, comporte de une à plusieurs manipulations à effectuer sur l’application.
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.
Le test d'intégration est une phase dans les tests, qui est précédée des tests unitaires. C’est le développeur qui s’occupe de les élaborer. Il s’agit de vérifier le bon fonctionnement des différents modules d’un code source et de leurs interactions. Ces test ressemblent beaucoup au tests unitaires. Pour différencier les tests unitaires et les test d’intégration, un test unitaire est fait pour tester un morceau de code ou un module seul, de façon cloisonné, tandis qu’un test d’intégration est fait pour tester l’assemblage et les interaction des mêmes modules.
Zennoposter élimine la répétition fastidieuse de vérifier les mêmes sites tous les jours, de mémoriser les mots de passe et de remplir les formulaires Web. Grâce aux templates que vous élaborez, il peut remplir automatiquement les formulaires Web qui s’étendent sur plusieurs pages. Toutes les informations sont stockées dans des fichiers textes lisibles par l’humain et peuvent être édités facilement.

Les tests de qualité représentent une étape nécessaire et indispensable pour garantir la livraison d’une application moderne et robuste ayant le minimum possible de défauts : La satisfaction des utilisateurs et l’augmentation de la productivité des développeurs seront garantis. Par ailleurs, afin de préserver leur productivité, il est indispensable aux équipes organisées en mode agile d’adopter l’automatisation des tâches répétitives et particulièrement les tests fonctionnels étant donné qu’ils représentent généralement la tâche la plus lourde en terme de temps. L’automatisation vient donc en faveur de l’agilité grâce à la rapidité d’exécution, la flexibilité face aux modifications du code.
Automation of homes and home appliances is also thought to impact the environment, but the benefits of these features are also questioned. A study of energy consumption of automated homes in Finland showed that smart homes could reduce energy consumption by monitoring levels of consumption in different areas of the home and adjusting consumption to reduce energy leaks (such as automatically reducing consumption during the nighttime when activity is low). This study, along with others, indicated that the smart home’s ability to monitor and adjust consumption levels would reduce unnecessary energy usage. However, new research suggests that smart homes might not be as efficient as non-automated homes. A more recent study has indicated that, while monitoring and adjusting consumption levels does decrease unnecessary energy use, this process requires monitoring systems that also consume a significant amount of energy. This study suggested that the energy required to run these systems is so much so that it negates any benefits of the systems themselves, resulting in little to no ecological benefit.[54]
Au cours de nos missions, nous avons identifié les facteurs que les sociétés informatiques doivent prendre en compte pour estimer l’effort manuel nécessaire à l’automatisation des tests. Parmi ces facteurs : la complexité du langage utilisé pour la création des scripts de test et le volume de travail requis pour planifier, produire, exécuter et maintenir les scripts. Un autre élément contribuant à l’estimation de l’effort consiste à classer les tests par niveau de complexité (simple, moyenne, complexe) en fonction du nombre de transactions et du nombre d’étapes définis par les scripts requis pour chaque cas.
Lors de la création d’un test, l’outil dispose généralement d’un pointeur d’objets qui met en avant l’objet situé sous le pointeur de la souris. La reconnaissance de cet objet passe par la comparaison de ses propriétés à celles des objets ou types d’objets présents dans le référentiel. Si la correspondance entre l’objet pointé et celui du référentiel est forte, il est alors possible de définir avec une grande probabilité que l’objet pointé est du même type que celui du référentiel.
Afin de profiter au mieux de l’automatisation des tests, voici huit recommandations issues de notre expérience, acquise au cours de plus de 50 projets internationaux d’automatisation des tests en entreprise. Ces conseils sont destinés à aider l’amélioration du retour sur investissement en automatisation de tests et à améliorer la qualité logicielle.
La définition des tests automatisés pour les applications de bureau (comme les applications sur les systèmes d’exploitation de Windows) est assez compliqué vu que un petit changement peut provoquer des bugs et des anomalies. Les outils suivants permettent de créer et d’exécuter les tests de l’Interface Graphique pour divers plates-formes et systèmes d'exploitation.
En ce qui concerne l’Extreme Programming, c’est une des méthodes issue de la méthodologie Agile, qui préconise d'écrire les tests en même temps, voire avant même le développement de la fonction à tester. Il s’agit du Test Driven Development ou Développement piloté par les tests.. Ceci permet de définir précisément l'interface du module à développer. On écrit la procédure de test qui reproduit le bogue avant de développer la fonctionnalité. Une fois la fonctionnalité développé, on lance le test, qui ne doit indiquer aucune erreur. Nous reparlerons un peu plus tard de cette méthode.
C'est peut être toujours pas très claire donc je vais vous donné un exemple ! Sur facebook il y a souvent des groupes de revente de place de concert (quand les événements sont complet par exemple), le seul soucis c'est qu'a moins d’être derrière son ordi toute la journée généralement quand quelqu'un vend sa place 5 min après elle est déjà vendu et t'es passé sous le nez ...
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).
IFTTT (If This Then That) est l’outil le plus connu en matière d’automatisation de tâches. Disponible dans une version web ainsi que sous la forme d’applications mobiles pour les plateformes Android et IOS, il permet de créer des petits programmes baptisés « applets ». Leurs rôles ? Etablir des interactions entre les différents outils numériques que l’on utilise au quotidien afin d’automatiser des tâches courantes.
Parmi les frameworks les plus appréciés, on trouve les frameworks « pilotés par les données », où les données de test sont stockées indépendamment de l’outil d’automatisation. L’utilisation et la personnalisation des rapports sont ainsi simplifiées, de même que la maintenabilité des données, et de multiples cas de test peuvent être réalisés sur plusieurs jeux de données en entrée. Toutefois, les coûts initiaux ainsi que ceux de la maintenance peuvent être considérables.
Many roles for humans in industrial processes presently lie beyond the scope of automation. Human-level pattern recognition, language comprehension, and language production ability are well beyond the capabilities of modern mechanical and computer systems (but see Watson (computer)). Tasks requiring subjective assessment or synthesis of complex sensory data, such as scents and sounds, as well as high-level tasks such as strategic planning, currently require human expertise. In many cases, the use of humans is more cost-effective than mechanical approaches even where automation of industrial tasks is possible. Overcoming these obstacles is a theorized path to post-scarcity economics.
29. L’automatisation des tests fonctionnels SIMON Emeline Annexe 4 : Exemple de test avec Selenium, classe Selenium. public class selenium { private Selenium selenium; @Before public void setUp() throws Exception { WebDriver driver = new FirefoxDriver(); String baseUrl = "http://localhost:8080/tutoselenium"; selenium = new WebDriverBackedSelenium(driver, baseUrl); } @Test public void testSelenium() throws Exception { // Connexion au site selenium.open("/tutoselenium/"); // On est page 1, on va page 2 selenium.type("id=contentForm:pageText", "2"); selenium.click("id=contentForm:nextPage"); selenium.waitForPageToLoad("30000"); // puis page 3 selenium.click("id=contentForm:page3Button"); selenium.waitForPageToLoad("30000"); // et retour page 1 selenium.select("id=contentForm:pageList_input", "value=1"); selenium.click("id=contentForm:nextPageButton"); selenium.waitForPageToLoad("30000"); // On passe en anglais selenium.click("id=headerForm:english_button"); // etc. } @After public void tearDown() throws Exception { selenium.stop(); } }
Maintenant que notre environnement Python, que les bilbiothèques Selenium et PhantomJS ont été installées, et que nous avons eu un aperçu du fonctionnement de chaque "bloc", voici un script qui va reprendre et montrer l'étendue des possibilités dans le scripting de macros sous Python. Ce script va réaliser les actions suivantes : il va se rendre sur le moteur de recherche Google, il va taper le mot clé "Campus Booster" puis effectuer une recherche, il va cliquer sur le premier lien, saisir les identifiants Campus Booster et ainsi se connecter, puis va retourner l'URL de la page une fois connecté ainsi qu'un screenshot, le tout sans quitter la ligne de commande ni ouvrir de navigateur (en vrai, un navigateur s'ouvre de manière invisible, il s'agit du navigateur PhantomJS).
des outils de compréhension de la structure des systèmes et de leur comportement, et une composante pratique car l'automatique a pour fin de faire fonctionner des systèmes en minimisant l'intervention humaine pour éviter toutes sortes de tâches fastidieuses, répétitives ou dangereuses, et donc d'en permettre l'automatisation […] Lire la suite☛ http://www.universalis.fr/encyclopedie/automatique/#i_2513
Les logiciels de tests fonctionnels cherchent à reproduire le comportement d’un utilisateur lors de l’utilisation d’une application. L’outil doit donc reconnaître les actions et évènements déclenchés sur les différents éléments de l’interface. La reconnaissance des objets est ainsi importante car si l’outil arrive à reconnaître un objet en utilisant ses caractéristiques et non pas par ses coordonnées à l’écran, le test sera de meilleure qualité et pourra être réutilisé même en cas d’une réorganisation des objets à l’écran.

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.


26. L’automatisation des tests fonctionnels SIMON Emeline Annexe 1 : Exemple de plan de test sur le lot 6 du logiciel IGC, Groupama Gan Vie. Cette image représente un plan de test se déroulant sur 8 semaines. On peut y observé les dates pour chaque période, le nombre de jours alloué à la période indiquée, le thème à recetter, le ou les acteurs (les testeurs), le nombre de cas à tester par thème et le nombre total. Ce plan permet à chaque ressources de savoir ce qu’elle a à faire et en combien de temps. Tous les acteurs de la recette sont ainsi informés de la situation.
Worldline [Euronext : WLN] est le leader européen et un acteur mondial de référence dans le secteur des paiements et des services transactionnels. Worldline met en place des services nouvelle génération, permettant à ses clients d’offrir au consommateur final des solutions innovantes et fluides. Acteur clef du B2B2C, riche de plus de 40 ans d’expérience, Worldline sert et contribue au succès de toutes les entreprises et administrations, dans un marché en perpétuelle évolution. Worldline propose un Business Model unique et flexible, construit autour d’un portefeuille d’offres évolutif et global permettant une prise en charge end-to-end. Les activités de Worldline sont organisées autour de trois axes : Merchant Services & Terminals, Mobility & e-Transactional Services, Financial Processing & Software Licensing. Worldline emploie plus de 7 300 collaborateurs dans le monde entier et a généré un revenu de 1,22 milliard d’euros en 2015. Worldline est une entreprise du Groupe Atos. worldline.com
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.
×