Re-Introducing PHPUnit: Getting Started with TDD in PHP
This article provides a modern introduction to PHPUnit for a contemporary PHP development environment. We'll build a simple command-line tool that converts JSON to PHP arrays, demonstrating key PHPUnit concepts along the way.
We assume familiarity with object-oriented PHP (PHP 7 or higher). For a streamlined setup, use Homestead Improved, which pre-installs PHP 7 and simplifies the process. Some command-line usage is involved, but we'll guide you through it.
Key Concepts:
- PHPUnit: A testing framework for PHP that simplifies test creation and execution, promoting code quality and Test-Driven Development (TDD).
- Test-Driven Development (TDD): A methodology where tests are written before the code, guiding development and ensuring expected behavior. Assertions verify expected outcomes.
-
Setup: Involves creating a project with Composer, installing PHPUnit as a development dependency (
composer require phpunit/phpunit --dev
), and configuringphpunit.xml
to manage test suites and bootstrapping. -
First Test: Extend
PHPUnitFrameworkTestCase
, use assertions (assertEquals
, etc.) to define expected results, driving functional code development. - Data Providers: Cleanly organize tests by separating test data from logic. Easily add new test cases without modifying test methods.
- Code Coverage: Reports identify untested code, ensuring comprehensive testing and application robustness.
Test-Driven Development Explained:
TDD involves writing tests to define how code should behave before writing the code itself. Assertions (assertEquals
, assertTrue
, etc.) check if the code meets expectations. A failed test indicates a need for code changes.
PHPUnit Overview:
PHPUnit provides tools (classes and executables) to simplify test writing and analysis. It generates reports showing code quality, coverage, and more.
Example Application: JSON to PHP Array Converter
We'll create a command-line tool to convert JSON files to PHP arrays. Assume a PHP 7 environment with Composer. If using Homestead Improved, ssh
into the VM (vagrant ssh
).
-
Project Setup:
cd Code git clone https://github.com/php-pds/skeleton converter cd converter composer require phpunit/phpunit --dev rm bin/* src/* docs/* tests/*
Copy after loginCopy after login -
Front Controller (index.php in converter/public):
<?php echo "Hello world";
Copy after loginCopy after login -
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>
Copy after loginCopy after login -
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/*
Copy after loginCopy after login -
composer.json (updated): (Replace template values with your project details)
<?php echo "Hello world";
Copy after loginCopy after login -
Run
composer dump-autoload
-
First 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>
Copy after loginCopy after login -
Run Tests (
php vendor/bin/phpunit
) (Expect failure initially) -
Implement Converter Class (src/SitePoint/Converter/Converter.php):
<?php require_once __DIR__ . '/../vendor/autoload.php';
Copy after login -
Re-run tests. (Should now pass)
The remainder of the tutorial details adding more tests, using data providers for cleaner code, and setting up code coverage reports using XDebug. The final sections include FAQs covering TDD and PHPUnit best practices. The complete code is available on Github (link provided in original text).
The above is the detailed content of Re-Introducing PHPUnit: Getting Started with TDD in PHP. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

Alipay PHP...

JWT is an open standard based on JSON, used to securely transmit information between parties, mainly for identity authentication and information exchange. 1. JWT consists of three parts: Header, Payload and Signature. 2. The working principle of JWT includes three steps: generating JWT, verifying JWT and parsing Payload. 3. When using JWT for authentication in PHP, JWT can be generated and verified, and user role and permission information can be included in advanced usage. 4. Common errors include signature verification failure, token expiration, and payload oversized. Debugging skills include using debugging tools and logging. 5. Performance optimization and best practices include using appropriate signature algorithms, setting validity periods reasonably,

Session hijacking can be achieved through the following steps: 1. Obtain the session ID, 2. Use the session ID, 3. Keep the session active. The methods to prevent session hijacking in PHP include: 1. Use the session_regenerate_id() function to regenerate the session ID, 2. Store session data through the database, 3. Ensure that all session data is transmitted through HTTPS.

The application of SOLID principle in PHP development includes: 1. Single responsibility principle (SRP): Each class is responsible for only one function. 2. Open and close principle (OCP): Changes are achieved through extension rather than modification. 3. Lisch's Substitution Principle (LSP): Subclasses can replace base classes without affecting program accuracy. 4. Interface isolation principle (ISP): Use fine-grained interfaces to avoid dependencies and unused methods. 5. Dependency inversion principle (DIP): High and low-level modules rely on abstraction and are implemented through dependency injection.

How to debug CLI mode in PHPStorm? When developing with PHPStorm, sometimes we need to debug PHP in command line interface (CLI) mode...

Article discusses essential security features in frameworks to protect against vulnerabilities, including input validation, authentication, and regular updates.

The enumeration function in PHP8.1 enhances the clarity and type safety of the code by defining named constants. 1) Enumerations can be integers, strings or objects, improving code readability and type safety. 2) Enumeration is based on class and supports object-oriented features such as traversal and reflection. 3) Enumeration can be used for comparison and assignment to ensure type safety. 4) Enumeration supports adding methods to implement complex logic. 5) Strict type checking and error handling can avoid common errors. 6) Enumeration reduces magic value and improves maintainability, but pay attention to performance optimization.

How to automatically set the permissions of unixsocket after the system restarts. Every time the system restarts, we need to execute the following command to modify the permissions of unixsocket: sudo...
