Kernpunkte
- phpunit wandelt den nativen Fehlern der PHP -Fehler in Ausnahmen um, wodurch der Codeausführung während des Tests geändert werden kann. Dies kann beim Testen von Code mithilfe von
trigger_error()
-Funktionen Probleme verursachen. - phpunit wandelt Fehler in Ausnahmen um, wodurch sich der Code in der Entwicklung und Tests unterschiedlich verhalten als in Produktionsumgebungen. Dies liegt daran, dass sich der Ausführungsprozess ändert, wenn ein Fehler auftritt.
- Um den Code mit
trigger_error()
genau zu testen, können Sie einen benutzerdefinierten Fehlerhandler verwenden, um Fehlerinformationen für die spätere Analyse mit Ansaugen zu erfassen. Auf diese Weise kann der Code die Ausführung fortsetzen und gleichzeitig die Überprüfung der Fehlerbedingung ermöglicht.
Das Standardverhalten der Einheit der Einheit ist für genaue Tests von entscheidender Bedeutung. Bei einer Logik nach dem Auslösen kann die Ergänzung der Funktionalität von Phpunit genaue Tests so nahe wie möglich an der Produktionsumgebung ermöglichen.
Funktionen aufzeichnet. In der Zwischenzeit schreiben Sie Unit -Tests für diesen Code mit Phpunit. Wenn Sie sich auf das Phpunit -Handbuch beziehen, gibt es einen Abschnitt, der die Prüfung der Fehlerbedingungen gewidmet ist. Es beschreibt, wie Phpunit seinen eigenen Fehlerhandler implementiert, der Fehler, Warnungen und Benachrichtigungen in Ausnahmen umwandelt, und diese Ausnahmen zu erfassen, ist, wie Sie mit solchen Fehlertests umgehen sollten. Abhängig vom Erscheinungsbild Ihres Code können Sie jedoch Probleme mit diesem Ansatz mit Phpunit haben. Dieser Artikel erläutert ausführlich, was dieses Problem ist, wie sich dies auf Ihre Fähigkeit auswirkt, Ihren Code zu testen, und wie er löst. trigger_error()
Was ist das Problem?
Fehler und Ausnahmen verhalten sich grundsätzlich anders. Insbesondere im Zusammenhang mit diesem Artikel kann die Codeausführung unmittelbar nach unmittelbar nach trigger_error()
in Bezug auf diesen Artikel in Bezug auf einen tödlichen Fehler angezeigt. Wenn eine Ausnahme ausgelöst wird, wird die Ausführung am Anfang des catch
-Blocks fortgesetzt, der dieser Ausnahmegementen entspricht, die unmittelbar nach dem Punkt auftreten kann oder nicht, an dem die Ausnahme ausgelöst wird. Schauen wir uns einige Beispiele für diese Verhaltensweisen an. Zunächst ist es ein Fehler.
<?php error_reporting(E_ALL | E_STRICT); echo "Before warning\n"; trigger_error("Danger Will Robinson!", E_USER_WARNING); echo "After warning\n"; ?>
Wenn Sie den oben genannten Code ausführen, erhalten Sie die folgende Ausgabe:
<code>Before warning PHP Warning: Danger Will Robinson! in /home/matt/error_handler.php on line 4 After warning</code>
Daraus können wir sehen, dass die trigger_error()
-Antage nach der Ausführung der echo
. Nun, Ausnahme.
<?php try { echo "Before exception\n"; throw new Exception("Danger Will Robinson!"); echo "After exception\n"; } catch (Exception $e) { echo "In catch block\n"; } ?>
Ausgabe:
<code>Before exception In catch block</code>
Im Gegensatz zum Fehlerbeispiel wird der Code nach der Ausnahme nicht ausgeführt. Da Phpunit einen Fehler in eine Ausnahme umwandelt, verhält sich der Fehler mit der Ausnahme in Unit -Tests genauso. Während des Tests wird kein Code ausgeführt, der nach Auslöser eines Fehlers ausgeführt wird. Geben Sie ein anderes Beispiel an:
<?php function foo($param) { if (is_string($param)) { trigger_error(__FUNCTION__ . " no longer supports strings, pass an array", E_USER_NOTICE); } // do useful stuff with $param ... } ?>
Mit der Revertierung von Fehler zu der Ausnahme ist es unmöglich zu testen, ob $param
nützlich behandelt wird, da der Code niemals ausgeführt wird, wenn der Fehler in eine Ausnahme konvertiert wird.
Nebenwirkungen des Phpunit -Verhaltens
Dieser Fehler zur Ausnahme von Fehler führt dazu, dass sich der Code in der Entwicklung und Tests unterschiedlich verhalten als in Produktionsumgebungen. Hier ist ein Beispiel:
<?php error_reporting(E_ALL | E_STRICT); echo "Before warning\n"; trigger_error("Danger Will Robinson!", E_USER_WARNING); echo "After warning\n"; ?>
Ausgabe:
<code>Before warning PHP Warning: Danger Will Robinson! in /home/matt/error_handler.php on line 4 After warning</code>
Der erste var_dump()
Aufruf (während dieser Zeit wird ein benutzerdefinierter Fehlerhandler, der den Fehler in eine Ausnahme konvertiert, wirkt sich aus) nimmt null aus. Der zweite var_dump()
-Aufruf (in dem der Standardfehlerhandler von PHP wirksam wird) gibt Informationen über den ausgelösten Fehler aus. Beachten Sie, dass dies nicht darauf zurückzuführen ist, dass der erste var_dump()
-Anrufausgang Null durch die Verwendung eines benutzerdefinierten Fehlerhandlers verursacht wird, sondern weil der Fehlerhandler eine Ausnahme ausgelöst hat. Wenn der in diesem Beispiel angezeigte Fehlerhandler dies nicht tut, ist die Ausgabe des ersten var_dump()
-Anrufs der zweiten.
Lösung
Wir benötigen eine Lösung, die es ermöglicht, den getesteten Code weiter auszuführen und gleichzeitig zu überprüfen, ob eine Fehlerbedingung angehoben wurde. Wie im obigen Beispiel gezeigt, kann die Fortsetzung der Codeausführung mit einem benutzerdefinierten Fehlerhandler erfolgen, der Fehler nicht in Ausnahmen umwandelt. Dieser Fehlerhandler sollte die Fehlermeldung so erfassen, dass sie später mit Behauptungen analysiert werden kann. So sieht es aus:
<?php try { echo "Before exception\n"; throw new Exception("Danger Will Robinson!"); echo "After exception\n"; } catch (Exception $e) { echo "In catch block\n"; } ?>
setUp()
(vor jeder Testmethode ausführen) verarbeitet ein Einrichten eines Fehlerhandlers, bei dem es sich nur um eine andere Methode in derselben Klasse handelt, die Informationen zu jedem Fehler in einem Array speichert. Andere Methoden (z. B. assertError()
) werden dann mit Testmethoden (z. B. testDoStuff()
) verwendet, um Aussagen zu dieser Fehlermeldung durchzuführen und relevante Debug -Informationen auszugeben, z. B. der Fehler, der im Vergleich zum erwarteten Fehler ausgelöst wird. Weitere nützliche Behauptungen sind die logische Inversion (d. H. Die Behauptungen auslösen keinen bestimmten Fehler), Fehler, die Meldungen überprüfen, mit einem regulären Ausdruck oder der Anzahl der ausgelösten Fehler entsprechen.
Schlussfolgerung
Wenn es Ihnen egal ist, ob die Logik hinter dem Test, das einen Fehler auslöst, weiterhin ausgeführt wird, ist das Standardverhalten von Phpunit perfekt für Ihre Anforderungen geeignet. Es ist jedoch wichtig, dass Sie verstehen, was das Verhalten bedeutet. Wenn Sie sich um die Ausführung einer solchen Logik kümmern, ist es auch wichtig, dass Sie wissen, wie Sie die Funktionen von Phpunit ergänzen, um genaue Tests Ihres Codes so nah wie möglich an der Produktionsumgebung zu ermöglichen.
Bilder aus Fotolien
(Folgendes ist FAQ, das Format und der Ausdruck wurden nach dem ursprünglichen Inhalt angepasst, und einige Probleme wurden zusammengeführt oder vereinfacht)
FAQs (FAQ) zur Verwendung von Phpunit, um Fehlerbedingungen zu testen
Q1: Warum zeigt Phpunit keine Fehler in der Konsole?
phpunit ist so konzipiert, dass fehler- und Ausnahmen wirksame Prüfung ermöglicht. Wenn Sie keine Fehler in der Konsole sehen, erfasst Phpunit sie möglicherweise und behandelt sie als fehlgeschlagene Tests. Um die Details dieser Fehler anzuzeigen, können Sie die Option --debug
beim Ausführen des Tests verwenden. Dies liefert eine detailliertere Ausgabe, einschließlich aller beim Testen gefangenen Fehler oder Ausnahmen.
Q2: Wie kann man behaupten, dass eine Ausnahme in Phpunit ausgelöst wurde?
phpunit liefert eine Reihe von Behauptungen, die speziell zur Behandlung von Ausnahmen verwendet werden. Das am häufigsten verwendete ist expectException()
, mit dem Sie die Art der Ausnahme angeben können, die Sie erwarten. Wenn die angegebene Ausnahme während des Tests ausgelöst wird, wird der Test bestehen. Wenn nicht, fällt der Test fehl. Auf diese Weise können Sie Tests schreiben, die speziell auf die korrekte Handhabung der Fehlerbedingungen prüfen.
Q3: Wie funktioniert die Fehlerberichterstattung in PHP?
Mit der Fehlerberichterstattung von PHP können Sie steuern, welche Fehler gemeldet werden und wie Sie mit ihnen umgehen können. Standardmäßig werden alle Fehler gemeldet und angezeigt. Sie können diese Einstellungen jedoch mit der Funktion und der error_reporting()
INI -Anweisung ändern. Auf diese Weise können Sie bestimmte Arten von Fehlern ausblenden oder Fehler protokollieren, anstatt sie anzuzeigen. display_errors
Q4: Wie testet man Ausnahmen in Phpunit?
gleich wie Q2.
Q5: Wie schreibe ich Tests für Phpunit?
Das Schreiben von Tests für Phpunit beinhaltet die Erstellung einer neuen Testfallklasse, die die PhpunitFrameworkTestCase -Klasse erweitert. Jeder Test ist eine öffentliche Methode in dieser Klasse, beginnend mit dem Wort "Test". In jeder Testmethode können Sie die Behauptung von PHPUnit verwenden, um zu überprüfen, ob Ihr Code wie erwartet ausgeführt wird. Beispielsweise können Sie die -Methode verwenden, um zu überprüfen, ob die Funktion das erwartete Ergebnis zurückgibt. assertEquals()
Q6: Wie behandle ich Fehler in Phpunit?
phpunit liefert eine Reihe von Behauptungen, die speziell zur Behandlung von Fehlern verwendet werden. Das am häufigsten verwendete ist, mit dem Sie den Fehlertyp angeben können, den Sie erwarten. Wenn der angegebene Fehler während des Tests ausgelöst wird, besteht der Test. Wenn nicht, fällt der Test fehl. Auf diese Weise können Sie Tests schreiben, die speziell auf die korrekte Handhabung der Fehlerbedingungen prüfen. expectError()
Q7: Wie kann man Tests in Phpunit debuggen?
Phpunit bietet mehrere Optionen zum Debuggen von Tests. Die Option bietet detailliertere Ausgabe, einschließlich aller beim Test aufgenommenen Fehler oder Ausnahmen. Die Optionen --debug
, --stop-on-error
und --stop-on-failure
können verwendet werden, um den Test zu stoppen, wenn ein Fehler eines Typs auftritt. Dies kann es einfacher machen, Probleme zu identifizieren und zu beheben. --stop-on-risky
Q8: Wie testet man Fehlerbedingungen in Phpunit?
phpunit bietet verschiedene Möglichkeiten, um Fehlerbedingungen zu testen. Mit der expectError()
-Methode können Sie den Fehlertyp angeben, den Sie auslösen. Mit der expectWarning()
-Methode können Sie die Art der Warnung angeben, die Sie auslösen. Wenn der angegebene Fehler oder die angegebene Warnung während des Tests ausgelöst wird, wird der Test bestehen. Wenn nicht, fällt der Test fehl.
Q9: Wie geht es mit Warnungen in Phpunit um?
phpunit liefert eine Reihe von Behauptungen, die speziell für die Bewältigung von Warnungen verwendet werden. Das am häufigsten verwendete ist expectWarning()
, mit dem Sie die Art der Warnung angeben können, die Sie erwarten. Wenn die angegebene Warnung während des Tests ausgelöst wird, besteht der Test. Wenn nicht, fällt der Test fehl. Auf diese Weise können Sie Tests schreiben, die speziell die korrekte Handhabung der Warnbedingungen überprüfen.
Q10: Wie verwendet man Datenanbieter in Phpunit?
Datenanbieter ist eine leistungsstarke Funktion von PHPUnit, mit der Sie Tests mehrmals mit verschiedenen Datensätzen ausführen können. Um den Datenanbieter zu verwenden, können Sie eine Methode erstellen, die ein Array von Arrays zurückgibt. Jedes interne Array ist eine Reihe von Parametern für den Test. Anschließend kommentieren Sie Ihre Testmethode mit @dataProvider
gefolgt vom Namen Ihrer Datenanbietermethode. Phpunit wird dann den Test für jeden Parametersatz einmal ausgeführt und die Parameter an die Testmethode übergeben.
Das obige ist der detaillierte Inhalt vonPHP Master | Fehlerzustandstest mit Phpunit. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Die PHP -Protokollierung ist für die Überwachung und Debugie von Webanwendungen von wesentlicher Bedeutung sowie für das Erfassen kritischer Ereignisse, Fehler und Laufzeitverhalten. Es bietet wertvolle Einblicke in die Systemleistung, hilft bei der Identifizierung von Problemen und unterstützt eine schnellere Fehlerbehebung

Laravel vereinfacht die Behandlung von temporären Sitzungsdaten mithilfe seiner intuitiven Flash -Methoden. Dies ist perfekt zum Anzeigen von kurzen Nachrichten, Warnungen oder Benachrichtigungen in Ihrer Anwendung. Die Daten bestehen nur für die nachfolgende Anfrage standardmäßig: $ Anfrage-

Die PHP Client -URL -Erweiterung (CURL) ist ein leistungsstarkes Tool für Entwickler, das eine nahtlose Interaktion mit Remote -Servern und REST -APIs ermöglicht. Durch die Nutzung von Libcurl, einer angesehenen Bibliothek mit Multi-Protokoll-Dateien, erleichtert PHP Curl effiziente Execu

Laravel bietet eine kurze HTTP -Antwortsimulationssyntax und vereinfache HTTP -Interaktionstests. Dieser Ansatz reduziert die Code -Redundanz erheblich, während Ihre Testsimulation intuitiver wird. Die grundlegende Implementierung bietet eine Vielzahl von Verknüpfungen zum Antworttyp: Verwenden Sie Illuminate \ Support \ facades \ http; Http :: fake ([ 'Google.com' => 'Hallo Welt',, 'github.com' => ['foo' => 'bar'], 'Forge.laravel.com' =>

Möchten Sie den dringlichsten Problemen Ihrer Kunden in Echtzeit und Sofortlösungen anbieten? Mit Live-Chat können Sie Echtzeitgespräche mit Kunden führen und ihre Probleme sofort lösen. Sie ermöglichen es Ihnen, Ihrem Brauch einen schnelleren Service zu bieten

Alipay PHP ...

In Artikel wird die in PHP 5.3 eingeführte LSB -Bindung (LSB) erörtert, die die Laufzeitauflösung der statischen Methode ermöglicht, um eine flexiblere Vererbung zu erfordern. Die praktischen Anwendungen und potenziellen Perfo von LSB

In dem Artikel werden Frameworks hinzugefügt, das sich auf das Verständnis der Architektur, das Identifizieren von Erweiterungspunkten und Best Practices für die Integration und Debuggierung hinzufügen.


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

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

PHPStorm Mac-Version
Das neueste (2018.2.1) professionelle, integrierte PHP-Entwicklungstool

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

mPDF
mPDF ist eine PHP-Bibliothek, die PDF-Dateien aus UTF-8-codiertem HTML generieren kann. Der ursprüngliche Autor, Ian Back, hat mPDF geschrieben, um PDF-Dateien „on the fly“ von seiner Website auszugeben und verschiedene Sprachen zu verarbeiten. Es ist langsamer und erzeugt bei der Verwendung von Unicode-Schriftarten größere Dateien als Originalskripte wie HTML2FPDF, unterstützt aber CSS-Stile usw. und verfügt über viele Verbesserungen. Unterstützt fast alle Sprachen, einschließlich RTL (Arabisch und Hebräisch) und CJK (Chinesisch, Japanisch und Koreanisch). Unterstützt verschachtelte Elemente auf Blockebene (wie P, DIV),

Dreamweaver Mac
Visuelle Webentwicklungstools