Maison >développement back-end >tutoriel php >Comment utiliser le framework de tests unitaires PHP PHPUnit
Quand j'apprenais le développement IOS, j'ai écrit un article spécifiquement sur les tests unitaires en Objective-C pour l'apprentissage du développement IOS. Aujourd'hui, je vais résumer comment utiliser les tests unitaires en PHP.
Dans cet article, nous utilisons l'outil de gestion des packages de dépendances de composer
pour installer et gérer les packages phpunit
, adresse officielle du compositeur https:// getcomposer .org/, suivez simplement les instructions pour l'installer globalement. De plus, nous utiliserons également un composant de journalisation Monolog très facile à utiliser pour enregistrer les journaux pour notre commodité.
Créez le fichier de configuration coomposer.json
dans le répertoire racine et entrez le contenu suivant :
{ "autoload": { "classmap": [ "./" ] } }
Ce qui précède signifie charger tous les 类文件
dans le répertoire racine après avoir exécuté <.> sur la ligne de commande, un dossier composer install
sera généré dans le répertoire racine. Tout code tiers que nous installerons via vendor
à l'avenir sera généré ici. composer
Chaque fois que vous pensez à taper quelque chose dans une instruction d'impression ou une expression de débogage, remplacez-le par un test. --Martin Fowler
est un logiciel open source développé dans le langage de programmation PHP et est un framework de tests unitaires. PHPUnit a été créé par Sebastian Bergmann, dérivé de SUnit de Kent Beck, et est l'un des frameworks de la famille xUnit. PHPUnit
pour les tests automatiques rendra votre code plus robuste et réduira le coût de la maintenance ultérieure. Il s'agit également d'une spécification relativement standard. Les frameworks PHP populaires d'aujourd'hui ont tous des unités de test. comme Laraval, Symfony, Yii2, etc., les tests unitaires sont devenus la norme. phpunit
pour installer PHPUnit. Pour d'autres méthodes d'installation, veuillez voir icicomposer
composer require --dev phpunit/phpunit ^6.2Installer le package de journaux Monolog pour phpunit. tests et journalisation.
composer require monolog/monologAprès l'installation, nous pouvons voir que le fichier
contient déjà ces deux packs d'extension : coomposer.json
"require": { "monolog/monolog": "^1.23", }, "require-dev": { "phpunit/phpunit": "^6.2" },Utilisation simple de PHPUnit 1. , Test de fichier unique Créer un répertoire
, créer un nouveau fichier tests
, modifier comme suit : 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; } }
Explication du code :
PHPUnitFrameworkTestCase
, le test La méthode doit être testPushAndPop()
Les autorisations sont généralement représentées par public
, ou vous pouvez choisir d'ajouter des commentaires test开头
pour représenter @test
Utilisé pour faire des assertions sur la correspondance des valeurs réelles avec les valeurs attendues. assertEquals()
Exécution de la ligne de commande : Nom du fichier de test de la commande phpunit
➜ framework# ./vendor/bin/phpunit tests/StackTest.php // 或者可以省略文件后缀名 // ./vendor/bin/phpunit tests/StackTestRésultat de l'exécution :
➜ 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)Nous pouvons consulter les informations de notre journal imprimé dans le fichier
. app.log
<?php class Calculator { public function sum($a, $b) { return $a + $b; } } ?>Classe de test unitaire :
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)); } }Exécution de la commande :
> ./vendor/bin/phpunit tests/CalculatorTestRésultat de l'exécution :
PHPUnit 6.4.1 by Sebastian Bergmann and contributors. F 1 / 1 (100%) Time: 117 ms, Memory: 4.00MB There was 1 failure:Si nous écrivons délibérément l'assertion ici de manière erronée,
$this->assertEquals(1, $obj->sum(0, 0));
Regardez le résultat de l'exécution :
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.Les informations sur les erreurs de méthode et les numéros de ligne seront signalés directement, ce qui nous aide à trouver rapidement les bogues3 Utilisation avancéeVous en avez assez d'ajouter un devant chaque nom de méthode de test ? , êtes-vous confus parce que vous devez écrire plusieurs cas de test car les paramètres d'appel sont différents ? Ma fonctionnalité avancée préférée, que je vous recommande désormais, s'appelle
. 框架生成器
<?php class Calculator { public function sum($a, $b) { return $a + $b; } } ?>Ligne de commande pour démarrer le scénario de test, utilisez le mot-clé
--skeleton
> ./vendor/bin/phpunit --skeleton Calculator.phpRésultat de l'exécution :
PHPUnit 6.4.1 by Sebastian Bergmann and contributors. Wrote test class skeleton for Calculator to CalculatorTest.php.N'est-ce pas très simple ? Parce qu'il n'y a pas de données de test, ajoutez donc les données de test ici, puis réexécutez la commande ci-dessus
<?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; } } ?>Chaque méthode de la classe d'origine est testée pour le @assert annotation. Ceux-ci sont transformés en code de test, comme ceci
/** * Generated from @assert (0, 0) == 0. */ public function testSum() { $obj = new Calculator; $this->assertEquals(0, $obj->sum(0, 0)); }Résultats d'exécution :
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!