Cet article fournit une introduction moderne au phpunit pour un environnement de développement PHP contemporain. Nous allons créer un outil de ligne de commande simple qui convertit JSON en tableaux PHP, démontrant les concepts clés de phpunit en cours de route.
Nous assumons la familiarité avec le PHP orienté objet (PHP 7 ou plus). Pour une configuration rationalisée, utilisez Homestead améliorée, qui pré-installez PHP 7 et simplifie le processus. Une utilisation de la ligne de commande est impliquée, mais nous vous guiderons à travers cela.
Concepts clés:
composer require phpunit/phpunit --dev
) et configurer phpunit.xml
pour gérer les suites de tests et bootstrap. PHPUnitFrameworkTestCase
, utiliser des assertions (assertEquals
, etc.) pour définir les résultats attendus, conduisant le développement du code fonctionnel. Le développement axé sur le test a expliqué:
TDD implique d'écrire des tests pour définir comment le code devrait se comporter avant Écrivant le code lui-même. Assertions (assertEquals
, assertTrue
, etc.) Vérifiez si le code répond aux attentes. Un test échoué indique un besoin de modifications de code.
Présentation du phpunit:
PHPUnit fournit des outils (classes et exécutables) pour simplifier l'écriture et l'analyse des tests. Il génère des rapports montrant la qualité du code, la couverture et plus encore.
Exemple d'application: convertisseur JSON à PHP
Nous allons créer un outil de ligne de commande pour convertir les fichiers JSON en tableaux PHP. Supposons un environnement PHP 7 avec compositeur. Si l'utilisation de Homestead s'est améliorée, ssh
dans la machine virtuelle (vagrant ssh
).
Configuration du projet:
cd Code git clone https://github.com/php-pds/skeleton converter cd converter composer require phpunit/phpunit --dev rm bin/* src/* docs/* tests/*
Contrôleur avant (index.php dans le convertisseur / public):
<?php echo "Hello world";
phpunit.xml:
<?xml version="1.0" encoding="UTF-8"?> <phpunit bootstrap="tests/autoload.php"> <testsuites> <testsuite name="converter"> <directory suffix="Test.php">tests</directory> </testsuite> </testsuites> </phpunit>
tests / autoload.php:
cd Code git clone https://github.com/php-pds/skeleton converter cd converter composer require phpunit/phpunit --dev rm bin/* src/* docs/* tests/*
Composer.json (mis à jour): (Remplacez les valeurs du modèle par les détails de votre projet)
<?php echo "Hello world";
Run composer dump-autoload
Premier test (tests / sitepoint / converter / convertertest.php):
<?xml version="1.0" encoding="UTF-8"?> <phpunit bootstrap="tests/autoload.php"> <testsuites> <testsuite name="converter"> <directory suffix="Test.php">tests</directory> </testsuite> </testsuites> </phpunit>
Exécuter des tests (php vendor/bin/phpunit
) (attendez-vous à l'échec initialement)
Implémentez la classe de convertisseur (src / sitepoint / converter / converter.php):
<?php require_once __DIR__ . '/../vendor/autoload.php';
Re-Run Tests. (devrait maintenant passer)
Le reste des détails du tutoriel ajoutant plus de tests, à l'aide des fournisseurs de données pour le code plus propre et de la configuration des rapports de couverture de code à l'aide de XDebug. Les sections finales comprennent les FAQ couvrant les meilleures pratiques TDD et PHPUnit. Le code complet est disponible sur github (lien fourni dans le texte d'origine).
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!