Heim  >  Artikel  >  Backend-Entwicklung  >  So verwenden Sie das PHP-Unit-Test-Framework PHPUnit

So verwenden Sie das PHP-Unit-Test-Framework PHPUnit

一个新手
一个新手Original
2017-10-25 14:38:597861Durchsuche

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.

1. Vorwort

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

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

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

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

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

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 die

-Methode, um PHPUnit zu installieren. Weitere Installationsmethoden finden Sie hiercomposer

composer require --dev phpunit/phpunit ^6.2
Installieren Sie das Monolog-Protokollpaket für PHPUnit Testen und Protokollieren.

composer require monolog/monolog
Nach 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__ . &#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;
    }
}

Code-Erklärung:

  1. StackTest ist die Testklasse

  2. StackTest, geerbt von

    PHPUnitFrameworkTestCase

  3. Testmethode

    , dem Test Methode muss testPushAndPop()Berechtigungen werden im Allgemeinen durch public dargestellt, oder Sie können Kommentare test开头 hinzufügen, um @test

  4. in der Testmethode darzustellen, ähnlich wie bei Behauptungsmethoden wie

    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/StackTest
Ausfü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

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__ . &#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));

    }

}
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 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 finden

3. Erweiterte Verwendung

Sind 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

. 框架生成器

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 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!

Stellungnahme:
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