Heim >Backend-Entwicklung >PHP-Tutorial >Grundlegende Verwendung des PHP-Testframeworks PHPUnit
1. Vorwort
In diesem Artikel verwenden wir das Abhängigkeitspaketverwaltungstool von Composer, um PHPUnit-Pakete zu installieren und zu verwalten. getcomposer.org/, befolgen Sie einfach die Anweisungen, um es global zu installieren. Darüber hinaus werden wir zu unserer Bequemlichkeit auch eine sehr benutzerfreundliche Monolog-Protokollierungskomponente verwenden, um Protokolle aufzuzeichnen.
Erstellen Sie die Konfigurationsdatei von coomposer.json im Stammverzeichnis und geben Sie den folgenden Inhalt ein:
{ "autoload": { "classmap": [ "./" ] } }
Das Obige bedeutet, alle Klassendateien im Stammverzeichnis zu laden und sie auf Befehl auszuführen Zeile Nach der Composer-Installation wird im Stammverzeichnis ein Vendor-Ordner generiert. Jeder Code von Drittanbietern, den wir in Zukunft über Composer installieren, wird hier generiert.
2. Warum Unit-Tests?
Wenn Sie daran denken, etwas in eine Druckanweisung oder einen Debug-Ausdruck einzugeben, ersetzen Sie es durch einen Test. --Martin Fowler
PHPUnit ist eine Open-Source-Software, die in der Programmiersprache PHP entwickelt wurde und ein Unit-Test-Framework ist. PHPUnit wurde von Sebastian Bergmann erstellt, ist von Kent Becks SUnit abgeleitet und ist eines der Frameworks der xUnit-Familie.
Unit-Tests sind der Prozess des Testens einzelner Codeobjekte, wie z. B. Testfunktionen, Klassen und Methoden. Unit-Tests können jeden geschriebenen Testcode verwenden, oder Sie können einige vorhandene Test-Frameworks wie JUnit, PHPUnit oder Cantata++ verwenden. Das Unit-Testing-Framework bietet eine Reihe allgemeiner und nützlicher Funktionen, die Menschen beim Schreiben automatisierter Erkennungseinheiten unterstützen , beispielsweise eine Behauptung, die prüft, ob ein tatsächlicher Wert mit dem erwarteten Wert übereinstimmt. Unit-Testing-Frameworks enthalten oft Berichte für jeden Test und bieten Ihnen die Codeabdeckung, die Sie abgedeckt haben.
Kurz gesagt, die Verwendung von phpunit für automatische Tests macht Ihren Code robuster und reduziert die Kosten für die spätere Wartung. Es handelt sich außerdem um eine relativ standardmäßige Spezifikation, die alle über Unit-Tests verfügt , Symfony, Yii2 usw., Unit-Tests sind zum Standard geworden.
Darüber hinaus steuern Unit-Testfälle das Testskript über Befehle, anstatt über den Browser auf die URL zuzugreifen.
3. Installieren Sie PHPUnit
Verwenden Sie Composer, um PHPUnit zu installieren. Weitere Installationsmethoden finden Sie hier.
composer require --dev phpunit/phpunit ^6.2
Installieren Monolog-Protokollpaket, das zum Testen und Protokollieren von PHP-Einheiten verwendet wird.
composer require monolog/monolog
Nach der Installation können wir sehen, dass die Datei coomposer.json bereits diese beiden Erweiterungspakete enthält:
"require": { "monolog/monolog": "^1.23", }, "require-dev": { "phpunit/phpunit": "^6.2" },
4. Einfache Verwendung von PHPUnit
1. Einzeldateitest
Erstellen Sie das Verzeichnis Tests, erstellen Sie eine neue Datei StackTest.php und bearbeiten Sie sie wie folgt:
<?php /** * 1、composer 安装Monolog日志扩展,安装phpunit单元测试扩展包 * 2、引入autoload.php文件 * 3、测试案例 * * */ namespace App\tests; require_once __DIR__ . '/../vendor/autoload.php'; define("ROOT_PATH", dirname(__DIR__) . "/"); use Monolog\Logger; use Monolog\Handler\StreamHandler; use PHPUnit\Framework\TestCase; class StackTest extends TestCase { public function testPushAndPop() { $stack = []; $this->assertEquals(0, count($stack)); array_push($stack, 'foo'); // 添加日志文件,如果没有安装monolog,则有关monolog的代码都可以注释掉 $this->Log()->error('hello', $stack); $this->assertEquals('foo', $stack[count($stack)-1]); $this->assertEquals(1, count($stack)); $this->assertEquals('foo', array_pop($stack)); $this->assertEquals(0, count($stack)); } public function Log() { // create a log channel $log = new Logger('Tester'); $log->pushHandler(new StreamHandler(ROOT_PATH . 'storage/logs/app.log', Logger::WARNING)); $log->error("Error"); return $log; } }
Code Erklärung:
StackTest ist eine Testklasse
StackTest erbt von PHPUnitFrameworkTestCase
Testmethode testPushAndPop() muss über öffentliche Berechtigungen verfügen und beginnt normalerweise mit test oder Ihnen Sie können Kommentare hinzufügen. @test stellt dar:
In der Testmethode werden Assertionsmethoden ähnlich wie „assertEquals()“ verwendet, um Aussagen über die Übereinstimmung zwischen dem tatsächlichen Wert und dem erwarteten Wert zu treffen.
Befehlszeilenausführung:
Phunit-Befehlstestdateibenennung
➜ framework# ./vendor/bin/phpunit tests/StackTest.php // 或者可以省略文件后缀名 // ./vendor/bin/phpunit tests/StackTest
Ausführungsergebnisse:
➜ framework# ./vendor/bin/phpunit tests/StackTest.php PHPUnit 6.4.1 by Sebastian Bergmann and contributors. . 1 / 1 (100%) Time: 56 ms, Memory: 4.00MB OK (1 test, 5 assertions)
Wir können sehen, was wir in der Datei app.log gedruckt haben Protokollinformationen.
2. Einführung in die Klassendatei
Calculator.php
<?php class Calculator { public function sum($a, $b) { return $a + $b; } } ?>
Einheitentestklasse:
CalculatorTest.php
<?php namespace App\tests; require_once __DIR__ . '/../vendor/autoload.php'; require "Calculator.php"; use PHPUnit\Framework\TestCase; class CalculatorTest extends TestCase { public function testSum() { $obj = new Calculator; $this->assertEquals(0, $obj->sum(0, 0)); } }
Befehlsausführung:
> ./vendor/bin/phpunit tests/CalculatorTest
Ausführungsergebnis:
PHPUnit 6.4.1 by Sebastian Bergmann and contributors. F 1 / 1 (100%) Time: 117 ms, Memory: 4.00MB There was 1 failure:
Wenn wir die Behauptung hier absichtlich falsch schreiben, $this->assertEquals(1, $obj->sum(0 , 0));
Sehen Sie sich die Ausführungsergebnisse an:
PHPUnit 6.4.1 by Sebastian Bergmann and contributors. F 1 / 1 (100%) Time: 117 ms, Memory: 4.00MB There was 1 failure: 1) App\tests\CalculatorTest::testSum Failed asserting that 0 matches expected 1. /Applications/XAMPP/xamppfiles/htdocs/web/framework/tests/CalculatorTest.php:22 FAILURES! Tests: 1, Assertions: 1, Failures: 1.
meldet direkt die Methodenfehlermeldung und die Zeilennummer, was uns hilft, den Fehler schnell zu finden
3. Erweiterte Verwendung
Sind Sie es leid, vor jedem Testmethodennamen einen Test einzufügen? Fällt es Ihnen schwer, mehrere Testfälle zu schreiben, weil die von Ihnen aufgerufenen Parameter unterschiedlich sind? Meine bevorzugte erweiterte Funktion, die ich Ihnen jetzt empfehle, heißt Frame Builder.
Calculator.php
<?php class Calculator { public function sum($a, $b) { return $a + $b; } } ?>
Befehlszeile zum Starten des Testfalls, verwenden Sie das Schlüsselwort --skeleton
> ./vendor/bin/phpunit --skeleton Calculator.php
Ausführungsergebnis:
PHPUnit 6.4.1 by Sebastian Bergmann and contributors. Wrote test class skeleton for Calculator to CalculatorTest.php.
Ist nicht Ist es ganz einfach? Da keine Testdaten vorhanden sind, fügen Sie hier Testdaten hinzu und führen Sie dann den obigen Befehl erneut aus.
<?php class Calculator { /** * @assert (0, 0) == 0 * @assert (0, 1) == 1 * @assert (1, 0) == 1 * @assert (1, 1) == 2 */ public function sum($a, $b) { return $a + $b; } } ?>
Jede Methode in der Originalklasse wird auf die Annotation @assert getestet. Diese werden wie folgt in Testcode umgewandelt:
/** * Generated from @assert (0, 0) == 0. */ public function testSum() { $obj = new Calculator; $this->assertEquals(0, $obj->sum(0, 0)); }
Ausführungsergebnisse:
Empfohlenes Tutorial: „PHP-Tutorial“
Das obige ist der detaillierte Inhalt vonGrundlegende Verwendung des PHP-Testframeworks PHPUnit. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!