Das Erstellen effektiver React -Komponenten -Tests sollten intuitiv, unkompliziert und leicht aufrechterhalten werden. Die aktuellen Ökosysteme für die Testbibliothek fallen jedoch häufig zu kurz und behindern Entwickler, konsequent robuste JavaScript -Tests zu schreiben. Testen von React-Komponenten und das DOM erfordert häufig höhere Wrapper mit beliebten Testläufern wie Scherz oder Mokka.
Die Herausforderung: mühsame und verwirrende Tests
Aktuelle Testmethoden erweisen sich oft mühsam und verwirrend. Der jQuery-ähnliche Kettenstil zum Ausdruck von Testlogik ist umständlich und entspricht nicht der Komponentenarchitektur von React. Sogar scheinbar lesbarer Code wie diesen mit Enzym kann übermäßig ausführlich werden:
erwarten (screen.find (". view"). erwarten (screen.find ("h3"). text ()). toequal ("Technologies:"); erwarten (screen.find ("ul"). Kinder ()). to.have.lengthof (4); erwarten (screen.contains ([ // ... ])). an.equal (wahr); erwarten (screen.find ("button"). text ()). toequal ("zurück"); erwarten (screen.find ("button"). hasclass ("klein")). an.equal (true);
Dies entspricht einer relativ einfachen Dom -Struktur:
<div classname="view technologies"> <h3 id="Technologien">Technologien:</h3> <ul> <li>JavaScript</li> <li> Reactjs</li> <li> Nodejs</li> <li> Webpack</li> </ul> <button classname="small">Zurück</button> </div>
Das Testen komplexerer Komponenten verstärkt diese Probleme und macht den Prozess noch unhandlicher. Die Trennung zwischen den Prinzipien von React zur Erzeugung von HTML und dem Testansatz führt zu ineffizienten und schwer zu mainten Tests. Eine einfache JavaScript-Verkettung reicht für langfristige Wartbarkeit nicht aus.
Es treten zwei wichtige Probleme auf:
- Komponentenspezifischer Testansatz: So schreiben Sie effektiv auf das Komponentenverhalten zugeschnittene Tests.
- Minimierung der Redundanz: So beseitigen Sie unnötigen Code und verbessern Sie die Lesbarkeit der Tests.
Lassen Sie uns diese ansprechen, bevor wir praktische Lösungen erkunden.
Ein fokussierter Ansatz zum Reagieren von Komponententests
Betrachten Sie eine grundlegende React -Komponente:
Funktion Willkommen (Requisiten) { zurückkehren<h1 id="Hallo-props-name"> Hallo, {props.name}</h1> ; }
Diese Funktion akzeptiert props
und gibt einen DOM -Knoten mit JSX zurück. Da Komponenten im Wesentlichen Funktionen sind, beinhaltet das Testen mit der Überprüfung des Funktionsverhaltens: Wie Argumente das zurückgegebene Ergebnis beeinflussen. Für React -Komponenten führt dies zum Einrichten von props
und zur Validierung des gerenderten DOM. Benutzerinteraktionen (Klicks, Mausover usw.), die die Benutzeroberfläche ändern, müssen ebenfalls programmatisch ausgelöst werden.
Verbesserung der Testerlesbarkeit: Das Muster für das ARMIM-Act-Assert
Klare, lesbare Tests sind entscheidend. Dies wird durch kurze Formulierungen und konsistente Struktur erreicht. Das AAA-Muster (arrang-act-Assert (AAA) ist ideal:
- Anordnen: Bereiten Sie die Komponentenrequisiten vor.
- Act: Rendern Sie die Komponente und auslösen Benutzerinteraktionen.
- ASSERT: Überprüfen Sie die erwarteten Ergebnisse basierend auf dem Markup der Komponente.
Beispiel:
it ("sollte auf eine große Schaltfläche klicken", () => { // Arrangieren props.size = "groß"; // Akt const component = montage (send); Simulate (Komponente, {Typ: "klicken"}); // Assert Erwarten Sie (Komponente, "Klasse haben", "geklickt"); });
Für einfachere Tests können Phasen kombiniert werden:
it ("sollte mit benutzerdefiniertem Text rendern", () => { Erwarten (senden, wenn "montiert", "Text haben", "senden"); });
Verbesserung der aktuellen Testpraktiken
Die vorherigen Beispiele sind zwar konzeptionell solide, aber mit Standardwerkzeugen nicht leicht zu erreichen. Betrachten Sie diesen häufigeren Ansatz:
it ("sollte die Technologienansicht anzeigen", () => { const container = document.createelement ("div"); document.body.Appendchild (Container); act (() => { Reactdom.render (<profilecard></profilecard> , Behälter); }); const button = container.querySelector ("button"); act (() => { button.dispatchEvent (neues Fenster. }); const details = container.querySelector (". Details"); erwarten (details.classlist.contains ("Technologies")). tobe (true); });
Vergleichen Sie dies mit einer abstrakteren Version:
it ("sollte die Technologienansicht anzeigen", () => { const component = montage (<profilecard></profilecard> ); Simulate (Komponente, {Typ: "Klicken", Ziel: "Schaltfläche"}); erwarten (Komponente, "für Test -ID gefragt", "Details", "Klasse haben", "Technologies"); });
Dies ist sauberer und lesbarer. Diese Abstraktionsniveau ist mit Unerwartesjs erreichbar.
Testen mit Unerwartes
UnerwartesJs ist eine erweiterbare Assertion -Bibliothek, die mit verschiedenen Test -Frameworks kompatibel ist. Das Plugin -System und die Syntax vereinfachen die React -Komponenten -Tests. Wir werden uns auf die Verwendung und Beispiele konzentrieren, anstatt uns tief in die inneren Arbeiten von Unerwartesworfwartes zu befassen.
Beispiel: Eine Profilkartenkomponente
Wir testen eine ProfileCard
-Komponente (Code für Kürze weggelassen, jedoch im referenzierten Github -Repository verfügbar).
Einrichten des Projekts
Um mitzumachen, klonen Sie das Github -Repository und befolgen Sie die Anweisungen, um das Projekt einzurichten und die Tests auszuführen.
Komponententests
Die Tests (in src/components/ProfileCard/ProfileCard.test.js
) verwenden das AAA -Muster:
- Prop -Setup:
beforeEach
stellt Standard -Requisiten ein.
vorab (() => { props = { Daten: { Name: "Justin Case", Beiträge: 45, CreationDate: "01.01.2021", }, }; });
Spezifische Testfälle: Beispiele sind Testen für das Symbol "Online", Biotext, die Technologienansicht (mit und ohne Daten), Standortanzeige, Rückruffunktionsausführung und Rendern mit Standardrequisiten. Jeder Testfall zeigt deutlich das ordnungsgemäße Act-Assert-Muster. (Detaillierte Testfälle sind für Kürze weggelassen, jedoch im Github -Repo verfügbar).
Ausführende Tests: Alle Tests werden mit
yarn test
ausgeführt.
Abschluss
Dieses Beispiel zeigt einen effektiveren Ansatz für die Reaktionskomponentenprüfung. Indem Sie Komponenten als Funktionen betrachten und das AAA -Muster verwenden, können Sie wartbare und lesbare Tests erstellen. Die Wahl der Testbibliothek sollte sich an der Fähigkeit geleitet werden, die Rendering von Komponenten und DOM -Vergleiche effektiv zu verarbeiten. UnerwartesJs ist in dieser Hinsicht ein starker Anwärter. Entdecken Sie das bereitgestellte Github -Repository für ein vollständiges Verständnis und weitere Experimente.
Das obige ist der detaillierte Inhalt vonReagieren Sie Komponententests für Menschen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Ich habe diese Frage neulich bekommen. Mein erster Gedanke ist: seltsame Frage! Bei der Spezifität geht es um Selektoren, und Rules sind keine Selektoren, also ... irrelevant?

Ja, Sie können, und es ist nicht wirklich wichtig in welcher Reihenfolge. Ein CSS -Präprozessor ist nicht erforderlich. Es funktioniert in regulären CSS.

Sie sollten auf jeden Fall weitausgestellte Cache-Header auf Ihren Vermögenswerten wie CSS und JavaScript (und Bilder und Schriftarten und was auch immer) festlegen. Das sagt dem Browser

Viele Entwickler schreiben darüber, wie sie eine CSS -Codebasis pflegen können, aber nicht viele von ihnen schreiben darüber, wie sie die Qualität dieser Codebasis messen. Sicher, wir haben

Haben Sie jemals ein Formular gehabt, das ein kurzes, willkürliches Stück Text akzeptieren musste? Wie ein Name oder was auch immer. Das ist genau das, wofür es ist. Es gibt viele

Ich bin so aufgeregt, nach Zürich, der Schweiz, zur Frontkonferenz zu gehen (liebe diesen Namen und diese URL!). Ich war noch nie in der Schweiz, also bin ich aufgeregt

Eine meiner Lieblingsentwicklungen in der Softwareentwicklung war das Aufkommen von Serverless. Als Entwickler, der die Tendenz hat, sich in den Details festzuhalten

In diesem Beitrag werden wir eine E -Commerce -Store -Demo verwenden, die ich für Netlify erstellt und bereitgestellt habe, um zu zeigen, wie wir dynamische Routen für eingehende Daten erstellen können. Es ist fair


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

SecLists
SecLists ist der ultimative Begleiter für Sicherheitstester. Dabei handelt es sich um eine Sammlung verschiedener Arten von Listen, die häufig bei Sicherheitsbewertungen verwendet werden, an einem Ort. SecLists trägt dazu bei, Sicherheitstests effizienter und produktiver zu gestalten, indem es bequem alle Listen bereitstellt, die ein Sicherheitstester benötigen könnte. Zu den Listentypen gehören Benutzernamen, Passwörter, URLs, Fuzzing-Payloads, Muster für vertrauliche Daten, Web-Shells und mehr. Der Tester kann dieses Repository einfach auf einen neuen Testcomputer übertragen und hat dann Zugriff auf alle Arten von Listen, die er benötigt.

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Herunterladen der Mac-Version des Atom-Editors
Der beliebteste Open-Source-Editor

MinGW – Minimalistisches GNU für Windows
Dieses Projekt wird derzeit auf osdn.net/projects/mingw migriert. Sie können uns dort weiterhin folgen. MinGW: Eine native Windows-Portierung der GNU Compiler Collection (GCC), frei verteilbare Importbibliotheken und Header-Dateien zum Erstellen nativer Windows-Anwendungen, einschließlich Erweiterungen der MSVC-Laufzeit zur Unterstützung der C99-Funktionalität. Die gesamte MinGW-Software kann auf 64-Bit-Windows-Plattformen ausgeführt werden.