Maison interface Web js tutoriel Guide de tests unitaires React : Comment garantir la qualité du code frontal

Guide de tests unitaires React : Comment garantir la qualité du code frontal

Sep 26, 2023 pm 01:45 PM
react 单元测试 Qualité du code frontal

Guide de tests unitaires React : Comment garantir la qualité du code frontal

Guide des tests unitaires React : Comment garantir la qualité du code front-end

Introduction :
Avec le développement et la complexité du développement front-end, garantir la qualité du code front-end est devenu particulièrement important. En tant que bibliothèque JavaScript populaire, React nécessite également des tests unitaires efficaces pour garantir la fiabilité et la stabilité du code. Cet article vous présentera quelques concepts et pratiques de base des tests unitaires React, ainsi que des exemples de code spécifiques.

1. Concepts de base des tests unitaires React

  1. Définition des tests unitaires : Les tests unitaires font référence à une activité de développement qui vérifie la plus petite unité testable d'un logiciel. Dans le développement front-end, les composants React sont traités comme une unité et nous pouvons tester unitairement la fonctionnalité, la logique et l'interaction des composants.
  2. Choix du framework de test : il existe de nombreux excellents frameworks de test parmi lesquels choisir dans l'écosystème React, tels que Jest, Enzyme et React Testing Library. Dans cet article, nous expliquerons Jest et Enzyme à titre d'exemples.

2. Installez et configurez l'environnement de test

  1. La commande pour installer Jest et Enzyme est la suivante :

    npm install jest enzyme enzyme-adapter-react-16 --save-dev
    Copier après la connexion
  2. Créez le fichier jest.config.js dans le répertoire racine du projet et configurez le contenu suivant :

    module.exports = {
      verbose: true,
      setupFilesAfterEnv: ['<rootDir>/src/setupTests.js'],
    };
    Copier après la connexion
  3. Créez le fichier setupTests.js dans le dossier src et configurez le contenu suivant :

    import Enzyme from 'enzyme';
    import Adapter from 'enzyme-adapter-react-16';
    
    Enzyme.configure({ adapter: new Adapter() });
    Copier après la connexion

3. Pratique des tests unitaires React
Prenez un simple composant de compteur comme exemple pour présenter comment effectuer les tests unitaires React.

  1. Exemple de code du composant Counter :

    import React, { useState } from 'react';
    
    const Counter = () => {
      const [count, setCount] = useState(0);
    
      const increment = () => {
     setCount(count + 1);
      };
    
      const decrement = () => {
     if (count > 0) {
       setCount(count - 1);
     }
      };
    
      return (
     <div>
       <button onClick={decrement}>-</button>
       <span>{count}</span>
       <button onClick={increment}>+</button>
     </div>
      );
    };
    
    export default Counter;
    Copier après la connexion
  2. Écrivez un scénario de test pour le composant Counter, créez le fichier Counter.test.js et ajoutez le contenu suivant :

    import React from 'react';
    import { mount } from 'enzyme';
    import Counter from './Counter';
    
    describe('Counter组件', () => {
      it('初始count值为0', () => {
     const wrapper = mount(<Counter />);
     expect(wrapper.find('span').text()).toEqual('0');
      });
    
      it('点击+按钮时count自增', () => {
     const wrapper = mount(<Counter />);
     wrapper.find('button').at(2).simulate('click');
     expect(wrapper.find('span').text()).toEqual('1');
      });
    
      it('点击-按钮时count自减', () => {
     const wrapper = mount(<Counter />);
     wrapper.find('button').at(0).simulate('click');
     expect(wrapper.find('span').text()).toEqual('0');
     wrapper.find('button').at(0).simulate('click');
     expect(wrapper.find('span').text()).toEqual('0');
      });
    });
    Copier après la connexion

    Le scénario de test ci-dessus teste le composant Counter, dont la valeur initiale est 0. Lorsque vous cliquez sur le bouton +, le nombre augmente et lorsque vous cliquez sur le bouton -, le nombre diminue. En utilisant la méthode mount, nous pouvons simuler le cycle de vie du composant pour des tests interactifs.

4. Exécutez des tests unitaires et des rapports de couverture de test

  1. Ajoutez la commande suivante dans le fichier package.json :

    "scripts": {
      "test": "jest --coverage"
    }
    Copier après la connexion
  2. Exécutez la commande npm test pour exécuter tous les tests unitaires et générer un rapport de couverture de test. Vous pouvez consulter le rapport correspondant dans le dossier de couverture.

Conclusion : 
Grâce à l'introduction de cet article, vous avez compris les concepts et les pratiques de base des tests unitaires React, et comment utiliser Jest et Enzyme pour tester les composants React. Les tests unitaires améliorent non seulement la qualité du code, mais améliorent également l'efficacité et la maintenabilité du développement. J'espère que cet article vous a apporté de l'aide pour les tests unitaires dans votre projet React.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

La différence entre les tests de performances et les tests unitaires en langage Go La différence entre les tests de performances et les tests unitaires en langage Go May 08, 2024 pm 03:09 PM

Les tests de performances évaluent les performances d'une application sous différentes charges, tandis que les tests unitaires vérifient l'exactitude d'une seule unité de code. Les tests de performances se concentrent sur la mesure du temps de réponse et du débit, tandis que les tests unitaires se concentrent sur la sortie des fonctions et la couverture du code. Les tests de performances simulent des environnements réels avec une charge et une concurrence élevées, tandis que les tests unitaires s'exécutent dans des conditions de faible charge et en série. L'objectif des tests de performances est d'identifier les goulots d'étranglement des performances et d'optimiser l'application, tandis que l'objectif des tests unitaires est de garantir l'exactitude et la robustesse du code.

Analyse des avantages et inconvénients des outils de tests unitaires PHP Analyse des avantages et inconvénients des outils de tests unitaires PHP May 06, 2024 pm 10:51 PM

Analyse de l'outil de test unitaire PHP : PHPUnit : convient aux grands projets, fournit des fonctionnalités complètes et est facile à installer, mais peut être verbeux et lent. PHPUnitWrapper : adapté aux petits projets, facile à utiliser, optimisé pour Lumen/Laravel, mais a des fonctionnalités limitées, ne fournit pas d'analyse de couverture de code et dispose d'un support communautaire limité.

Intégration du framework Java et du framework front-end React Intégration du framework Java et du framework front-end React Jun 01, 2024 pm 03:16 PM

Intégration du framework Java et du framework React : Étapes : Configurer le framework Java back-end. Créer une structure de projet. Configurez les outils de construction. Créez des applications React. Écrivez les points de terminaison de l'API REST. Configurez le mécanisme de communication. Cas pratique (SpringBoot+React) : Code Java : Définir le contrôleur RESTfulAPI. Code React : obtenez et affichez les données renvoyées par l'API.

Comment utiliser la méthode de test basée sur des tables dans les tests unitaires Golang ? Comment utiliser la méthode de test basée sur des tables dans les tests unitaires Golang ? Jun 01, 2024 am 09:48 AM

Les tests basés sur des tables simplifient l'écriture de scénarios de test dans les tests unitaires Go en définissant les entrées et les sorties attendues via des tableaux. La syntaxe comprend : 1. Définir une tranche contenant la structure du scénario de test ; 2. Parcourez la tranche et comparez les résultats avec la sortie attendue. Dans le cas réel, un test basé sur une table a été effectué sur la fonction de conversion de chaîne en majuscules, et gotest a été utilisé pour exécuter le test et le résultat de réussite a été imprimé.

Tests unitaires PHP : comment concevoir des cas de test efficaces Tests unitaires PHP : comment concevoir des cas de test efficaces Jun 03, 2024 pm 03:34 PM

Il est crucial de concevoir des cas de tests unitaires efficaces, en adhérant aux principes suivants : atomiques, concis, reproductibles et sans ambiguïté. Les étapes comprennent : la détermination du code à tester, l'identification des scénarios de test, la création d'assertions et l'écriture de méthodes de test. Le cas pratique démontre la création de cas de test pour la fonction max(), en soulignant l'importance des scénarios de test et des assertions spécifiques. En suivant ces principes et étapes, vous pouvez améliorer la qualité et la stabilité du code.

Tests unitaires PHP : conseils pour augmenter la couverture du code Tests unitaires PHP : conseils pour augmenter la couverture du code Jun 01, 2024 pm 06:39 PM

Comment améliorer la couverture du code dans les tests unitaires PHP : utilisez l'option --coverage-html de PHPUnit pour générer un rapport de couverture. Utilisez la méthode setAccessible pour remplacer les méthodes et propriétés privées. Utilisez des assertions pour remplacer les conditions booléennes. Obtenez des informations supplémentaires sur la couverture du code grâce aux outils de révision du code.

Intégration des tests unitaires PHP et de la livraison continue Intégration des tests unitaires PHP et de la livraison continue May 06, 2024 pm 06:45 PM

Résumé : En intégrant le framework de tests unitaires PHPUnit et le pipeline CI/CD, vous pouvez améliorer la qualité du code PHP et accélérer la livraison des logiciels. PHPUnit permet la création de scénarios de test pour vérifier la fonctionnalité des composants, et les outils CI/CD tels que GitLabCI et GitHubActions peuvent exécuter automatiquement ces tests. Exemple : validez le contrôleur d'authentification avec des cas de test pour garantir que la fonctionnalité de connexion fonctionne comme prévu.

Bases des tests unitaires PHP : écriture de code robuste et maintenable Bases des tests unitaires PHP : écriture de code robuste et maintenable Jun 03, 2024 am 10:17 AM

PHPUnit est un framework de tests unitaires PHP populaire qui peut être utilisé pour écrire des cas de tests robustes et maintenables. Il contient les étapes suivantes : installer PHPUnit et créer le répertoire tests pour stocker les fichiers de test. Créez une classe de test qui hérite de PHPUnit\Framework\TestCase. Définir des méthodes de test commençant par « test » pour décrire la fonctionnalité à tester. Utilisez des assertions pour vérifier que les résultats attendus sont cohérents avec les résultats réels. Exécutez supplier/bin/phpunit pour exécuter des tests à partir de la racine du projet.

See all articles