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é.
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).
Ma dernière expérimentation m’a permis d’obtenir un ensemble de tests de non-régression pour une application web mobile, multiplateformes (Browser),  multilingue (Anglais/Français) et multi-environnement (QA/ DEV/ Intégration) en moins de 15 JP d’effort. Créer de nouveaux scénarios requiert environ 1 JP par scénario et la maintenance est de 0,5 JP par itération. Le temps d’exécution étant de 2 minutes par scénario.
Notre expérience dans la réalisation de campagnes marketing ainsi que notre expertise dans l’utilisation de logiciels et du digital rendent notre agence apte à répondre à vos besoins d’automatisation marketing. Nous vous accompagnerons pour mettre en place un scénario de campagne efficace et une solution technique fiable. Pour une campagne marketing pleinement performante nous pouvons également vous conseiller pour développer votre stratégie de marketing de contenu . Pour augmenter significativement vos conversions, combinez l’automatisation à un contenu marketing à forte valeur ajoutée.
À travers nightwatch et de nombreux autres framework il est possible de jouer les tests via des solutions externes (EX : BrowserStack, SauceLabs). Cela offre de nombreuses combinaisons navigateurs/OS et permet de jouer les tests sur mobile sans effort supplémentaire. De plus, cela retire l’entretien des OS, navigateurs, VMs sur lesquels sont joués les tests.
L’outil nécessite tout de même quelques minutes de prise en main, mais les possibilités sont infinies. Wildfire s’adapte vraiment à vos habitudes et à vos tâches récurrentes. Vous trouverez quelques exemples de workflows conçus pour les professionnels, mais pas que. Vous pouvez créer un CSV contenant vos sites préférés pour automatiser votre veille le matin : Wildfire peut vous permettre d’ouvrir automatiquement votre premier site préféré, scroller à votre convenance, fermer l’onglet, passer au suivant, et ainsi de suite. Les mauvaises langues diront que c’est un outil pour les fainéants, d’autres verront qu’il permet de gagner en productivité en se concentrant sur des tâches plus intéressantes. Une documentation est incluse et vous permet d’imaginer toutes les possibilités qu’offre Wildfire.
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.
Absolument ! Non seulement il peut vous aider à créer de nombreuses tâches automatisées, backlinking et SEO serait simple et facile une fois que vous arrivez à comprendre pleinement ses fonctions. Aussi, vous le trouverez très utile chaque fois que vous commercialisez sur des sites de réseautage social comme Facebook, Tumblr et Blogspot, pour n'en nommer que quelques-uns. C'est également très pratique lorsque vous utilisez des plateformes de médias sociaux ou des propriétés Web 2.0 pour créer des liens et générer du trafic. Avec ZennoPoster, vous pouvez facilement créer plusieurs comptes et créer des liens vers votre site Web sans perdre votre temps précieux. Vous pouvez gérer jusqu'à 100 comptes différents grâce à ce logiciel en raison de ses capacités multithread. De plus, il vous permet de contrôler un processus par l'utilisation de PHP ou de Javascript assez facilement.
Par exemple, selon les spécifications, si l’utilisateur rentre un identifiant ou un mot de passe erroné, il est renvoyé sur l’écran d’authentification et un message d’erreur est affiché. Le test consistera donc à contrôler que c’est effectivement le cas, et que le bon message est affiché à l’écran.Pour une explication détaillée de ce que chacun d'entre eux peut faire, consultez le guide de Podio.
Elle contient  une collection  d’API open-source qui sont utilisées pour automatiser le test d’une application Web. Disponible pour plusieurs langages, l’API permet de programmer des scripts d’actions à réaliser sur l’application Web directement dans le navigateur, pour en vérifier ensuite le comportement par inspection du document de la page Web.. Les actions à réaliser peuvent également être exportées depuis Selenium IDE.
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 !
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é.
Les champs obligatoires sont marqués d'un astérisque (*). Les informations de ce formulaire ne seront pas conservées et ne seront utilisées que pour vous répondre. Conformément à la règlementation applicable, vous disposez d’un droit d’accès, de rectification et d’opposition aux informations vous concernant. Pour plus d’informations sur le traitement de vos données, cliquez ici
Dans son acception moderne, le mot automatisation et ses proches concernent des techniques ou des processus complexes plutôt que des perfectionnements d'appareils simples et courants. Du reste, les réalisations ont largement précédé, en ce domaine, les études théoriques. C'est seulement l'effort industriel suscité par la Seconde Guerre mondiale qui a fourni l'occasion de mettre en place les disciplines de base, à caractère mathématique. Elles s'enrichissent de jour en jour et bénéficient parallèlement des travaux co [...]
La recette (ou test d'acceptation) est une phase de développement des projets, visant à assurer formellement que le produit est conforme aux spécifications. Il ne s’agit plus de tester une fonctionnalité précise comme c’est le cas avec les tests fonctionnels, mais bien de tester l’application dans sa globalité. Pour cela, des scenarii de tests sont la plupart du temps utilisés afin de refléter une utilisation réelle de l’application. Ces tests peuvent être réalisés par le chef de projet fonctionnel ou par le client.
Dans le chapitre « Genèse des recherches en indexation automatique »  : […] Plusieurs facteurs ont incité les chercheurs en informatique documentaire à tenter de concurrencer l'indexation humaine. D'abord, les contraintes et les insuffisances inhérentes à celle-ci : elle est coûteuse (il faut entre un quart d'heure et une heure pour indexer un document) ; elle est tributaire de la subjectivité de l'indexeur (deux analystes […] Lire la suite☛ http://www.universalis.fr/encyclopedie/indexation/#i_2513
×