Im Softwareentwicklungsprozess ist das Testen ein wesentlicher Bestandteil. Durch Tests können Entwickler sicherstellen, dass ihr Code ordnungsgemäß ausgeführt wird und dass Komponenten zusammenarbeiten. Im PHP-Entwicklungsprozess ist PHPUnit ein beliebtes Testtool, das Entwicklern dabei helfen kann, Tests zu automatisieren und Testergebnisse zu zählen.
Die neueste Version von PHPUnit kann von der offiziellen Website heruntergeladen und mit Composer installiert werden. Nachdem Sie PHPUnit heruntergeladen und installiert haben, können Sie die Datei phpunit.xml konfigurieren und die Einstellungen für PHPUnit einschließen. Die Syntax von phpunit.xml ähnelt XML-Tags, in denen verschiedene Einstellungen, Parameter und Geräte definiert werden können.
In der obigen Datei phpunit.xml stehen viele Optionen zur Verfügung, einige der wichtigsten sind:
Zusätzlich zu den oben genannten Optionen gibt es viele weitere Optionen, die eingestellt werden können. Die entsprechenden Konfigurationsoptionen finden Sie in der PHPUnit-Dokumentation.
PHPUnit kann jeden gültigen PHP-Code testen. Der Testplan kapselt den Code in ein Testmakro, das mit dem Schlüsselwort „assertion“ beginnt. Durch die Ausführung dieser Testmakros fragt PHPUnit Ihren Code automatisch, ob er wie erwartet ausgeführt wird. Hier ist ein einfacher Test:
<?php use PHPUnitFrameworkTestCase; class MyTest extends TestCase { public function testTrueIsTrue() { $this->assertTrue(true); } } ?>
In diesem Beispiel wird die TestCase-Klasse von PHPUnit verwendet, um einen Test zu definieren, und alle Tests erben standardmäßig davon. In diesem Test gibt es nur eine Funktion, testTrueIsTrue, und wir verwenden AssertTrue, um einen echten Ausdruck zu testen. Das Ergebnis gibt eine „OK“- oder „FAIL“-Zeichenfolge zurück, die das Testergebnis angibt.
Zusätzlich zu „asserTrue“ stellt PHPUnit auch viele andere Testmethoden zur Verfügung, wie zum Beispiel „asserContains“, das mit „asserTrue“ vergleicht, aber die Werte von Arrays und Strings vergleichen kann.
Nachdem Sie Ihre Tests geschrieben haben, können Sie PHPUnit ausführen, um die Tests auszuführen. Um PHPUnit in der Befehlszeile auszuführen, können Sie den folgenden Befehl verwenden:
phpunit [Optionen] [Argumente]
wobei Optionen einige Optionen für PHPUnit sind und Argumente angeben, welche Tests ausgeführt werden sollen. Wenn keine Argumente verwendet werden, sucht PHPUnit im aktuellen Verzeichnis nach allen auszuführenden Tests. Wenn Sie mehrere Tests haben, können Sie Platzhalter verwenden, um den spezifischen Test anzugeben, der ausgeführt werden soll.
PHPUnit gibt die Ergebnisse aller Tests aus, einschließlich der Testdurchlauf- und -fehlerraten sowie Details zu einzelnen Testfällen. In der Ausgabe können Sie den Namen, die Laufzeit und die Ergebnisse jedes Tests sehen. Die Ausgabe enthält außerdem detaillierte Informationen, einschließlich des Codes für jeden Test und des Grundes für den fehlgeschlagenen Test. Die Ausgabe von
PHPUnit ist sehr hilfreich, da sie Entwicklern hilft, schnell zu verstehen, wie verschiedene Testfälle ausgeführt werden, und sicherzustellen, dass der Code in allen Situationen wie erwartet ausgeführt wird.
Das Folgende ist ein Beispiel für die Verwendung von PHPUnit zum Testen einer Webanwendung. In diesem Beispiel testen wir eine einfache Webanwendung, die eine API bereitstellt, mit der Benutzer Textnachrichten speichern und abrufen können.
Wir möchten zunächst testen, ob der Benutzer die Nachricht erfolgreich senden kann. Dies umfasst eine Reihe verschiedener Aspekte, einschließlich der Sicherstellung, dass die richtige URL aufgerufen wird, und der Überprüfung, ob die Antwort den richtigen HTTP-Statuscode enthält. Hier ist der Testcode:
<?php use PHPUnitFrameworkTestCase; class WebAppTest extends TestCase { private $http; protected function setUp(): void { $this->http = new GuzzleHttpClient(['base_uri' => 'http://localhost:8000']); } protected function tearDown(): void { $this->http = null; } public function testPostMessage() { $response = $this->http->request('POST', '/message', [ 'form_params' => [ 'message' => 'Hello!' ] ]); $this->assertEquals(200, $response->getStatusCode()); $this->assertContains('{"success": true}', $response->getBody()); } public function testGetMessage() { $response = $this->http->request('GET', '/message'); $this->assertEquals(200, $response->getStatusCode()); $this->assertContains('{"message": "Hello!"}', $response->getBody()); } } ?>
In diesem Beispiel richten wir zunächst einen Client ein, der eine Verbindung zu unserer Webanwendung herstellt. Überschreiben Sie die Methoden „setUp“ und „tearDown“, um sicherzustellen, dass jeder Test in einer sauberen Umgebung beginnt und endet. Anschließend haben wir zwei Tests geschrieben, einen zum Testen der POST-Anfrage zum Senden der Nachricht und einen zum Testen der GET-Anfrage zum Abrufen der Nachricht. In beiden Fällen vergleichen wir den resultierenden HTTP-Statuscode und den Antworttext. Wenn das Speichern oder Abrufen von Nachrichten fehlschlägt, erhalten wir auf diese Weise ein fehlgeschlagenes Testergebnis und stellen so sicher, dass unsere Anwendung wie erwartet funktioniert.
Zusammenfassung
PHPUnit ist eines der am häufigsten verwendeten Test-Frameworks in der PHP-Entwicklung. Es bietet viele nützliche Testtools und -optionen, die Entwicklern dabei helfen können, Tests einfacher durchzuführen und Statistiken über Testergebnisse während des Testprozesses zu erstellen. In der Praxis wird empfohlen, dass Entwickler PHPUnit verwenden, um Tests zu schreiben und Testcode zur Versionskontrolle hinzuzufügen, wenn sie Versionskontrolltools wie Git verwenden. Dies stellt die Zuverlässigkeit des Codes sicher und ermöglicht die rechtzeitige Erkennung und Reparatur von Codefehlern, wenn sie auftreten.
Das obige ist der detaillierte Inhalt vonSo verwenden Sie PHPUnit für Testergebnisstatistiken in der PHP-Entwicklung. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!