Heim > Backend-Entwicklung > PHP-Tutorial > Grundlegende Verwendung des PHP-Testframeworks PHPUnit

Grundlegende Verwendung des PHP-Testframeworks PHPUnit

Guanhui
Freigeben: 2023-04-08 16:18:02
nach vorne
3866 Leute haben es durchsucht

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": [
            "./"
        ]
    }
}
Nach dem Login kopieren

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
Nach dem Login kopieren

Installieren Monolog-Protokollpaket, das zum Testen und Protokollieren von PHP-Einheiten verwendet wird.

composer require monolog/monolog
Nach dem Login kopieren

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"
    },
Nach dem Login kopieren

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__ . &#39;/../vendor/autoload.php&#39;;
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, &#39;foo&#39;);
        // 添加日志文件,如果没有安装monolog,则有关monolog的代码都可以注释掉
        $this->Log()->error(&#39;hello&#39;, $stack);
        $this->assertEquals(&#39;foo&#39;, $stack[count($stack)-1]);
        $this->assertEquals(1, count($stack));
        $this->assertEquals(&#39;foo&#39;, array_pop($stack));
        $this->assertEquals(0, count($stack));
    }
    public function Log()
    {
        // create a log channel
        $log = new Logger(&#39;Tester&#39;);
        $log->pushHandler(new StreamHandler(ROOT_PATH . &#39;storage/logs/app.log&#39;, Logger::WARNING));
        $log->error("Error");
        return $log;
    }
}
Nach dem Login kopieren

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
Nach dem Login kopieren

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)
Nach dem Login kopieren

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;  
    }  
}  
?>
Nach dem Login kopieren
Nach dem Login kopieren

Einheitentestklasse:

CalculatorTest.php

<?php
namespace App\tests;
require_once __DIR__ . &#39;/../vendor/autoload.php&#39;;
require "Calculator.php";
use PHPUnit\Framework\TestCase;
class CalculatorTest extends TestCase
{
    public function testSum()
    {
        $obj = new Calculator;
        $this->assertEquals(0, $obj->sum(0, 0));
    }
}
Nach dem Login kopieren

Befehlsausführung:

> ./vendor/bin/phpunit tests/CalculatorTest
Nach dem Login kopieren

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:
Nach dem Login kopieren

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.
Nach dem Login kopieren

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;  
    }  
}  
?>
Nach dem Login kopieren
Nach dem Login kopieren

Befehlszeile zum Starten des Testfalls, verwenden Sie das Schlüsselwort --skeleton

> ./vendor/bin/phpunit --skeleton Calculator.php
Nach dem Login kopieren

Ausführungsergebnis:

PHPUnit 6.4.1 by Sebastian Bergmann and contributors.
Wrote test class skeleton for Calculator to CalculatorTest.php.
Nach dem Login kopieren

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;  
    }  
}  
?>
Nach dem Login kopieren

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));
    }
Nach dem Login kopieren

Ausführungsergebnisse:

Nach dem Login kopieren

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!

Verwandte Etiketten:
Quelle:segmentfault.com
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage