Heim >Backend-Entwicklung >PHP-Tutorial >So verwenden Sie das PHP-Unit-Test-Framework PHPUnit
Als ich die IOS-Entwicklung lernte, habe ich einen Artikel speziell über Unit-Tests in Objective-C geschrieben. Heute werde ich zusammenfassen, wie man Unit-Tests in PHP verwendet.
In diesem Artikel verwenden wir das Abhängigkeitspaketverwaltungstool von composer
, um phpunit
Pakete zu installieren und zu verwalten. Die offizielle Adresse des Composers ist https://getcomposer .org/, folgen Sie einfach den 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 coomposer.json
-Konfigurationsdatei im Stammverzeichnis und geben Sie den folgenden Inhalt ein:
{ "autoload": { "classmap": [ "./" ] } }
Das Obige bedeutet, dass alle 类文件
nach der Ausführung von in der Befehlszeile wird ein Ordner composer install
im Stammverzeichnis generiert. Jeder Code von Drittanbietern, den wir in Zukunft über vendor
installieren, wird hier generiert. composer
Wenn Sie daran denken, etwas in eine Druckanweisung oder einen Debug-Ausdruck einzugeben, ersetzen Sie es durch einen Test. --Martin Fowler
ist eine Open-Source-Software, die in der Programmiersprache PHP entwickelt wurde und ein Unit-Testing-Framework ist. PHPUnit wurde von Sebastian Bergmann erstellt, ist von Kent Becks SUnit abgeleitet und ist eines der Frameworks der xUnit-Familie. PHPUnit
für automatische Tests macht Ihren Code robuster und reduziert die Kosten für die spätere Wartung. Es handelt sich auch um eine relativ standardmäßige Spezifikation B. Laraval, Symfony, Yii2 usw., Unit-Tests sind zum Standard geworden. phpunit
-Methode, um PHPUnit zu installieren. Weitere Installationsmethoden finden Sie hiercomposer
composer require --dev phpunit/phpunit ^6.2Installieren Sie das Monolog-Protokollpaket für PHPUnit Testen und Protokollieren.
composer require monolog/monologNach der Installation können wir sehen, dass die
-Datei bereits diese beiden Erweiterungspakete enthält: coomposer.json
"require": { "monolog/monolog": "^1.23", }, "require-dev": { "phpunit/phpunit": "^6.2" },4 Einfache Verwendung von PHPUnit 1 , Einzeldateitest Verzeichnis erstellen
, neue Datei erstellen tests
, wie folgt bearbeiten: StackTest.php
<?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:
PHPUnitFrameworkTestCase
, dem Test Methode muss testPushAndPop()
Berechtigungen werden im Allgemeinen durch public
dargestellt, oder Sie können Kommentare test开头
hinzufügen, um @test
Wird verwendet, um Aussagen über die Übereinstimmung tatsächlicher Werte mit erwarteten Werten zu treffen. assertEquals()
Befehlszeilenausführung: phpunit-Befehlstestdateibenennung
➜ framework# ./vendor/bin/phpunit tests/StackTest.php // 或者可以省略文件后缀名 // ./vendor/bin/phpunit tests/StackTestAusführungsergebnis:
➜ 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 unsere gedruckten Protokollinformationen in der Datei
einsehen. app.log
<?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/CalculatorTestAusfü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 das Ausführungsergebnis 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.Methodenfehlerinformationen und Zeilennummern werden direkt gemeldet, was uns hilft, Fehler schnell zu finden3. Erweiterte VerwendungSind Sie es leid, vor jedem Testmethodennamen ein „Test“ hinzuzufügen? Sind Sie verwirrt, weil Sie mehrere Testfälle schreiben müssen, weil die Aufrufparameter unterschiedlich sind? Meine bevorzugte erweiterte Funktion, die ich Ihnen jetzt empfehle, heißt
. 框架生成器
<?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.phpAusführungsergebnis:
PHPUnit 6.4.1 by Sebastian Bergmann and contributors. Wrote test class skeleton for Calculator to CalculatorTest.php.Ist das nicht ganz einfach? Da es keine Testdaten gibt, 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 getestet @assert-Anmerkung. 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:
Das obige ist der detaillierte Inhalt vonSo verwenden Sie das PHP-Unit-Test-Framework PHPUnit. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!