25. HITEMA – Groupama Gan Vie L’automatisation des tests fonctionnels SIMON Emeline 24 Annexes Annexe 1 : Exemple de plan de test sur le lot 6 du logiciel IGC, Groupama Gan Vie. Annexe 2 : Exemple de suivi d’avancement format Tableau sur le logiciel TCS WEB, Groupama Gan Vie. Annexe 3 : Exemple de suivi d’avancement format courbe sur le lot 6 du logiciel IGC, Groupama Gan Vie. Annexe 4 : Exemple de test avec Selenium, classe Selenium

Votre site Web génère des appels, mais vous ne savez comment les visiteurs intéressés vous trouvent? Avec les bons outils, vous connaîtrez les sources payantes (publicité, réseaux sociaux, etc.) et serez ainsi en mesure d’optimiser vos investissements. Nous pouvons mesurer les ventes en ligne et les formulaires de contact mais aussi les appels téléphoniques!
Sans une planification rigoureuse du nombre requis de ressources qualifiées, tout programme de test automatisé échouera, victime d’interruptions de service inattendues, de retards et de dépassements de coûts. L’entreprise ne sera pas en mesure d’exécuter un nombre de tests suffisants, à un rythme suffisamment soutenu, pour pouvoir justifier l’investissement en automatisation de tests.
Pour ajouter des actions personnalisées à votre projet, cliquez simplement avec le bouton droit de la souris sur n’importe quel espace vide dans la zone du projet. Survolez « Ajouter une action » et survolez un type d’action à ajouter. Vous verrez alors toutes les actions qui sont à votre disposition. Il y a de multiples actions disponibles au sein de Zennoposter et apprendre chacune d’entre elles, ce qu’elle fait et quels sont ses paramètres et options peut prendre du temps. Ne soyez pas frustré si les choses ne progressent pas rapidement.
Aussi, les intervenants chargés des tests fonctionnels et des tests d’intégration en interne disposeraient d’une méthodologie adaptée pour tester l’application, ce qui rendrait ces opérations réellement efficace en permettant de remonter des anomalies qui n’aurait pas pu être identifiés autrement. Le client trouvera donc à son tour moins de bogues, ce qui permet de diminuer les aller-retours entre le client et la société et qui améliore la qualité du travail fourni au client.
L'assemblée nationale vote le budget de l'agriculture pour 2019 Yvelines: une boucherie aspergée de faux sang Foot: prison ferme pour violences pour le Danois Bendtner La part du diesel continue à baisser en France, à 36% en octobre (constructeurs) Zimbabwe: exploration sur la présence potentielle de gisements pétroliers (président) Vietnam: la France signe d'importants contrats, dont une commande pour Airbus de 5,7 mds EUR Nouvelle-Calédonie: Macron s'exprimera à 13H00 dimanche à l'issue du référendum Carburants: "le blocage n'est jamais la bonne solution", estime Guerini Cuba: Habanos prévoit des ventes de cigares en hausse malgré les lois anti-tabac La sonde américaine Dawn s'est éteinte
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.
Dans le chapitre «  Vers l'automatisation des échecs »  : […] L'aspiration à une automatisation des échecs ne s'est d'abord traduite que par des récits de fiction puis par de pseudo-robots comme Turc qui, en 1809, gagna une partie à Napoléon Ier et dans lequel un joueur de petite taille pouvait se loger à l'insu du public. La première réalisation véritable – elle était électromécanique […] Lire la suite☛ http://www.universalis.fr/encyclopedie/jeu-d-echecs/#i_2513

Pour le cas des tests Cooperons! les problématiques rencontrées sont les mêmes décrites au début de l’article en plus d’une autre particularité : On a besoin d’effectuer des mises en production fréquentes et livrer de nouvelles releases sur des intervalles rapprochés (parfois d’une façon hebdomadaire). Sachant que l’exécution de tout le cahier de test est effectuée par 3 testeurs/développeurs et nécessite entre 4 et 5 jours pour être finalisée. On a fini avec des deadlines non respectés et un processus de test plus lent et moins fiable. L’automatisation s’impose dans un tel cas. Les résultats obtenus sur Coopérons! grâce à l’automatisation ont permis de :
11. HITEMA – Groupama Gan Vie L’automatisation des tests fonctionnels SIMON Emeline 10 Il faut évidemment tester les scénarios « passants » : quels sont les résultats attendus pour une utilisation correcte ? Mais il faut également tester les scénarios non passants – aussi appelés « bloquants » : que se passe-t-il si je provoque une erreur ? La réponse à cette question est définie entre le client, la maitrise d’ouvrage et la maitrise d’œuvre. Il faut définir ce que le client attend et ce qui est réalisable, c’est la maitrise d’ouvrage qui effectue le lien entre les deux parties. Créer un scénario pour tester une fonctionnalité nécessite d’envisager une multitude de tests différents. Prenons l’exemple d’un champ de saisie à l’écran : si celui-ci attends un numéro de téléphone, il faut tester l’écriture d’un numéro de téléphone à 10 chiffres et vérifier que cela ne provoque pas d’erreur. Il faut également tester l’écriture de caractères (voire caractères spéciaux) pour provoquer une erreur. Mais aussi : un mix entre chiffre et lettres, un champ vide (ce champ est- il obligatoire ou facultatif ?), la taille du champ (celui-ci est-il limité ?)… Tous ces scénarios sont écris uniquement sur une seule et même «fonction » : celle du champ « numéro de téléphone ». Il y a donc environ 6 tests pour celui-ci, tout en sachant que l’on peut en faire 1, 2 ou plus, en fonction du temps imparti et de la pertinence des scénarios. Cet exemple basique prouve qu’il existe alors une quantité importante de tests pour une application. De nos jours, chaque logiciel ou applications possède plusieurs interfaces, composées elle-même de plusieurs fonctionnalités, boutons et autres actions. Ces actions peuvent être très simple comme l’exemple précédent ou bien plus compliquées : on peut imaginer des affichages de données en fonction de critères choisis, mais encore des envois de mails automatiques à des adresses différentes en fonction d’une maille entité / produit / objet. C. L’exécution de recette et les suivis d’avancement. Un cahier de recette correctement rédigé et précis, facilite grandement le travail à effectuer sans oublier de tests « évidents ». Cela permet également un suivi du travail effectué ou non, en cours, validé ou non. Ce cahier permet aussi de répertorier les problèmes rencontrés. En effet, le but étant de corriger les anomalies découvertes, il est ainsi très pratique de savoir pour chaque scénario ce qui pose problème. Lorsqu’un bogue est découvert, nous procédons comme suit : - Définir si le bogue est reproductible o Si oui, alors il est assez simple de définir la manipulation effectuée. o Si non, cela peut être dû à un problème qui n’est pas lié au développement, mais d’éléments externes (exemple : mauvaise connexion internet). Cela peut être également un problème « aléatoire ». Dans ce dernier cas, il est difficile de les résoudre. - Définir le périmètre du bogue : entité, écran, utilisateurs particuliers, etc. - Rapporter le bogue aux développeurs et le rapporter dans le cahier de tests. Pendant que l’anomalie est en cours d’analyse et de correction chez l’équipe de développement, la maitrise d’ouvrage peut poursuivre les autres tests. Lorsque le bogue est corrigé, un patch est alors appliqué et il est possible de tester à nouveau le scénario bloquant. Ce schéma est répété jusqu’à ce que le scénario soit complètement validé.
The centrifugal governor, which was invented by Christian Huygens in the seventeenth century, was used to adjust the gap between millstones.[20][21][22] Another centrifugal governor was used by a Mr. Bunce of England in 1784 as part of a model steam crane.[23][24] The centrifugal governor was adopted by James Watt for use on a steam engine in 1788 after Watt’s partner Boulton saw one at a flour mill Boulton & Watt were building.[16]
An early development of sequential control was relay logic, by which electrical relays engage electrical contacts which either start or interrupt power to a device. Relays were first used in telegraph networks before being developed for controlling other devices, such as when starting and stopping industrial-sized electric motors or opening and closing solenoid valves. Using relays for control purposes allowed event-driven control, where actions could be triggered out of sequence, in response to external events. These were more flexible in their response than the rigid single-sequence cam timers. More complicated examples involved maintaining safe sequences for devices such as swing bridge controls, where a lock bolt needed to be disengaged before the bridge could be moved, and the lock bolt could not be released until the safety gates had already been closed.

28. L’automatisation des tests fonctionnels SIMON Emeline Annexe 3 : Exemple de suivi d’avancement format courbe sur le lot 6 du logiciel IGC, Groupama Gan Vie. Sur cet exemple, le suivi d’avancement est réalisé à partir de quatre types de résultats : prévisionnel, révisé, exécuté, validé. Ces états permettent de situer le point d’avancement des équipes. Les deux schémas représentent le même suivi mais de façon différente : nombre de cas et pourcentage, et tous deux avec TNR (tests de Non régressions) inclus. L’état Prévisionnel est le nombre de tests prévu au départ, l’état « révisé » est le nombre de cas revu à chaque période (on peut dire Ajusté). L’état « exécuté » est le nombre de cas qui ont été testé, qu’ils soient OK ou KO. Enfin l’état « Validé » est le nombre de cas qui sont OK, donc corrects.
Business process automation (BPA) is the technology-enabled automation of complex[73] business processes. It can help to streamline a business for simplicity, achieve digital transformation, increase service quality, improve service delivery or contain costs. BPA consists of integrating applications, restructuring labor resources and using software applications throughout the organization. Robotic process automation is an emerging field within BPA and uses artificial intelligence. BPAs can be implemented in a number of business areas including marketing,[74] sales[75] and workflow.[76]
Pour automatiser vos campagnes de marketing, comptez un budget de plusieurs centaines d’euros. Ce budget inclut la réflexion stratégique sur le contenu de la campagne, les compétences techniques nécessaires à son automatisation et l’installation de logiciels si nécessaire. Le coût est bien entendu variable selon ce que vous souhaitez automatiser. Il reste important de noter que cette technique est aussi source de gain de temps et de clients !
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

Êtes-vous peut-être l'une de ces personnes qui passent trop de temps sur le travail de routine, ou peut-être que vous avez beaucoup d'idées en tête, mais que vous n'avez tout simplement pas le temps de les réaliser toutes ? Vous êtes peut-être l'un de ceux qui sont trop occupés pour étudier la programmation, mais qui souhaitent tout systématiser. Oui ? Eh bien, vous n'avez pas vraiment besoin de dépenser votre argent durement gagné pour des programmeurs et des pigistes. Avec ZennoPoster, c'est absolument possible ! Mais comment ?


Ainsi qu’évoqué plus haut, le plus grand défi à relever dans l’automatisation des tests est la difficulté à les maintenir dans le temps. Aussi pour répondre à cette problématique, nous avons mis en place différentes stratégies, parmi lesquelles l’utilisation du Page Object pattern, ou encore des pattern plus évolués comme le Screenplay pattern qui est une approche pour écrire du code de haute qualité pour les tests automatisé et qui est basés sur les principes du SOLID on peut citer à titre d’exemple, le Single Responsability principle ou le Open Closed principle.


3. HITEMA – Groupama Gan Vie L’automatisation des tests fonctionnels SIMON Emeline 2 Remerciements Je tiens à remercier dans un premier temps toute l’équipe pédagogique de l’école HITEMA. Je remercie Jean-Paul DAVID et Aurélien ARRIBEY, sans qui je n’aurais pu effectuer mon alternance chez Groupama Gan Vie. Je tiens à remercier Etienne BONTEMPS et Florence MOUGEL qui m’ont accompagné dans mon travail de tous les jours en m’apportant leur expérience et leurs conseils, leur écoute et leur pédagogie. Je remercie tout particulièrement Jérémy LE HELLOCO, mon tuteur depuis 2014, pour toute son attention et son suivi à mon égard, ses conseils et son expérience au sein de Groupama. Enfin, je remercie toute l’équipe de la MOA Collectives, pour leur écoute et leur soutien tout au long de mon apprentissage.
L’automatisation du test logiciel n’est ni aussi simple ni aussi rapide que semble l’indiquer cette appellation. Les outils de test logiciel peuvent s’avérer coûteux, tandis que la configuration, l’exécution et l’analyse des résultats de test exigent un effort manuel important. Toutefois, par l’usage d’outils adéquats, notamment de logiciels en Open source, et de processus et frameworks d’automatisation appropriés, les entreprises sont en mesure de réaliser des économies de coûts et de bénéficier de la qualité du test logiciel automatisé.
×