Welcome to the PHP Selenium Testing Framework project! This framework leverages Selenium and PHPUnit to automate browser testing for PHP applications. Below you'll find detailed information on how to set up, configure, and run the tests, as well as some tips to make the most of this powerful testing tool.
- Introduction
- Features
- Requirements
- Installation
- Configuration
- Usage
- Writing Tests
- Running Tests
- Project structure
- Screenshots
- Contributing
- License
This framework provides a robust environment for automated browser testing using Selenium WebDriver. It supports both parallel and sequential testing, ensuring optimal performance and resource utilization. Additionally, the framework includes webhook integration for sending HTML or JSON test reports, and provides the capability to save HTML reports directly on the server.
- Automated Browser Testing: Run your browser-based tests automatically.
- Selenium WebDriver Integration: Utilize the power of Selenium WebDriver for browser automation.
- PHPUnit Support: Write and manage your tests using PHPUnit.
- Docker Compatibility: Easily start Selenium using Docker.
- Automatic Test Discovery: Automatically discover and run tests located in the testsdirectory.
- Graceful Shutdown: Clean up Selenium sessions on script termination or interruption.
- Logs: Support of terminal, xml or json logging
- Parallel Testing: Run tests in parallel to optimize testing time and resources.
- Webhook Integration: Send HTML or JSON reports via webhooks.
- HTML Reports: Generate and save HTML reports on the server for detailed test analysis.
- PHP 7.4 or higher
- Composer
- Docker
- Clone the repository:
git clone https://github.com/kirilkirkov/PHP-Selenium-Testing-Framework.git- Install dependencies:
cd php-selenium-testing-framework composer install- Start Selenium with Docker:
docker run -d -e SE_NODE_MAX_SESSIONS=10 -p 4444:4444 -p 5900:5900 --shm-size=2g --restart=always selenium/standalone-firefox:latestSE_NODE_MAX_SESSIONS is important for maximum count of paralell tests.
Ensure you have the necessary configuration files:
- config.php: Add your specific configurations.
- helpers.php: Helper functions for your tests.
- Run the test script:
php run-tests.php- Interrupt the tests: Press Ctrl+C to stop the tests gracefully. This will ensure that the Selenium session is properly terminated.
Create your test classes in the tests directory. Test classes should follow the naming convention *Test.php and should be placed under the Tests namespace. Each separate test method should ends with suffix "_test".
Example test class:
<?php declare(strict_types=1); namespace Tests; // PHP-WebDriver use Facebook\WebDriver\WebDriverBy; use Facebook\WebDriver\WebDriverExpectedCondition; // PHPUnit use PHPUnit\Framework\TestCase; class SampleTest extends TestCase { private $driver; public function __construct(RemoteWebDriver $driver) { $this->driver = $driver; } public function beforeEachTest() { // Setup code before each test } public function afterEachTest() { // Cleanup code after each test } public function example_test() { // Your test code } }Execute the tests using the command provided in the Usage section. The framework will automatically discover and run all tests matching the pattern *Test.php in the tests directory.
You can watch the tests in real-time using a VNC viewer. The Selenium Docker image allows VNC connections with the following details:
- Host: localhost
- Port: 5900
- Password: secret
To connect using a VNC viewer:
- Download and install a VNC viewer (e.g., RealVNC, TigerVNC).
- Open the VNC viewer and connect to localhost:5900.
- When prompted, enter the password secret.
This allows you to observe the browser interactions as the tests are being executed.
PHP-Selenium-Testing-Framework-main/ ├── .gitignore # Specifies files and directories that should be ignored by Git ├── LICENSE # License file for the project ├── README.md # Project description and instructions ├── composer.json # Composer configuration file containing project dependencies and metadata ├── config.php # Configuration file for the project ├── helpers.php # Helper functions file ├── run-tests.php # Script to run the tests ├── src/ # Directory containing the main source code of the project │ ├── CmdMessages.php # File with command messages │ ├── HtmlReport.php # File for generating HTML reports │ ├── ParallelTesting.php # File for parallel test execution │ ├── Response.php # File for handling responses │ ├── ResultsContainer.php # File for the results container │ ├── TestsParser.php # File for parsing test files │ ├── TestsRunner.php # File for running tests │ └── Webhook.php # File for webhooks └── tests/ # Directory containing test files ├── FailTest.php # Sample example file for a failing test └── GithubRepoTest.php # Sample example file for testing a GitHub repositoryHTML Report:
We welcome contributions! Please follow these steps to contribute:
- Fork the repository.
- Create a new branch for your feature or bugfix.
- Commit your changes.
- Push your branch and create a Pull Request.
This project is licensed under the MIT License. See the LICENSE file for details.
