Blog ENI : Toute la veille numérique !
Accès illimité 24h/24 à tous nos livres & vidéos ! 
Découvrez la Bibliothèque Numérique ENI. Cliquez ici
Accès illimité 24h/24 à tous nos livres & vidéos ! 
Découvrez la Bibliothèque Numérique ENI. Cliquez ici

Travailler avec des environnements multiples

Cypress Cloud

Cypress Cloud, anciennement connu sous le nom de Cypress Dashboard, est une plateforme puissante conçue pour améliorer et simplifier le processus de test d’applications web en offrant des fonctionnalités de visualisation, de suivi et de gestion des tests automatisés.

Chaque exécution de test est stockée dans Cypress Cloud, où vous pouvez voir les résultats passés et l’état actuel de votre application sur la page Latest runs.

images/11RI07b.png

Les avantages de cette plateforme sont :

  • Exécution de tests en parallèle et équilibrage de charge : Cypress Cloud améliore considérablement l’exécution de tests en parallèle, permettant aux équipes de réduire le temps nécessaire pour exécuter de vastes suites de tests. Grâce à un équilibrage de charge intelligent, les tests sont automatiquement distribués à travers plusieurs machines ou conteneurs, optimisant ainsi le temps d’exécution global.

  • Insights et analytics approfondis : l’outil optimise la capacité d’analyse en fournissant des insights détaillés sur la performance des tests. Les équipes peuvent facilement identifier les goulots d’étranglement, les tests qui échouent fréquemment, et les tendances dans les temps d’exécution des tests, permettant ainsi une optimisation ciblée et efficace des efforts de test.

  • Intégration et collaboration améliorées : Cypress Cloud place un fort accent sur la facilitation de la collaboration au sein des équipes de développement et de QA. Avec des fonctionnalités telles que le partage facile de résultats de tests, les commentaires intégrés aux rapports de tests, et les notifications configurables, les équipes peuvent rester synchronisées et réagir rapidement aux problèmes identifiés.

  • Prise en charge étendue des environnements de test : reconnaissant la diversité des environnements de développement et de test utilisés par les équipes modernes, Cypress Cloud élargit sa compatibilité avec différents frameworks, langages de programmation, et infrastructures cloud. Cela permet une intégration transparente dans presque n’importe...

Tests parallèles et équilibrage de charge

Les tests parallèles consistent à exécuter simultanément différents tests ou suites de tests sur plusieurs machines ou threads, plutôt que de les exécuter séquentiellement sur une seule machine. Cette approche peut drastiquement réduire le temps d’exécution global des tests, ce qui est particulièrement bénéfique dans les contextes d’intégration continue/déploiement continu (CI/CD) comme Jenkins où la rapidité de feedback est primordiale.

Les tests parallèles avec Cypress présentent les avantages suivants :

  • Réduction du temps d’exécution des tests : idéal pour les projets avec un grand nombre de tests.

  • Utilisation optimisée des ressources : maximise l’utilisation des ressources disponibles en distribuant les tests sur plusieurs instances.

  • Amélioration de la productivité : permet aux équipes de développement de recevoir rapidement des retours sur les changements apportés.

1. Dans un job Jenkins

Tout d’abord, assurez-vous que votre serveur Jenkins est correctement configuré et que vous avez accès à un agent Jenkins (ou plusieurs agents) capable(s) d’exécuter des jobs en parallèle. Si vous utilisez des agents dans le cloud ou des conteneurs Docker comme agents, assurez-vous qu’ils sont configurés et prêts à être utilisés. La parallélisation fonctionne mieux avec Cypress Cloud.

Création d’un pipeline Jenkins

 Créez un nouveau job de type Pipeline dans Jenkins.

Dans la configuration du pipeline, vous allez définir les étapes de votre pipeline de CI qui incluent l’exécution de tests Cypress en parallèle.

Script Pipeline

Dans la section Pipeline script ou Pipeline script from SCM de la configuration de votre job, vous allez écrire ou référencer un script pipeline qui définit les étapes de build, y compris les tests parallèles. Voici un exemple de script utilisant la syntaxe Declarative Pipeline de Jenkins pour exécuter des tests Cypress en parallèle sur trois agents distincts.

pipeline {  
    agent none // Ne pas exécuter sur l'agent principal  ...

Conseils pour les tests basés sur le cloud

Vous avez vu que Cypress Cloud est très performant, voici donc quelques conseils pour l’utiliser au mieux :

  • Segmentez vos tests en petits scénarios ciblés plutôt que de créer de longs scripts de test. Cela réduit le temps d’exécution et facilite le débogage.

  • Utilisez des données de fixtures pour simuler les scénarios de test. Cela permet de réduire les dépendances externes et d’accélérer l’exécution des tests.

Les données de fixtures sont des fichiers utilisés pour stocker des données statiques qui peuvent être nécessaires pour les tests. Ces données peuvent inclure des exemples de réponses d’API, des configurations, etc. que vous souhaitez réutiliser dans vos tests. Par défaut, ces fichiers sont placés dans le dossier cypress/fixtures. Pour charger les données de fixture, vous devez utiliser la commande cy.fixture().

  • Profitez de la capacité de Cypress Cloud à exécuter des tests en parallèle. Cela peut considérablement réduire le temps global d’exécution de vos suites de tests.

  • Configurez différents environnements de test (développement, staging, production) dans Cypress Cloud pour assurer que vos tests sont exécutés dans le contexte...