leeovery / laravel-playwright
Backend stuff for Playwright e2e tests
Installs: 164
Dependents: 0
Suggesters: 0
Security: 0
Stars: 8
Watchers: 1
Forks: 0
Open Issues: 0
pkg:composer/leeovery/laravel-playwright
Requires
- php: ^8.3
- ext-pdo: *
- illuminate/support: ^11.0
- spatie/laravel-package-tools: ^1.14
Requires (Dev)
- laravel/pint: ^1.4
- orchestra/testbench: ^9.0
- pestphp/pest: *
- phpunit/phpunit: ^11.0
- rector/rector: ^2.2
- rector/rector-laravel: ^2.1
README
Backend utilities for Playwright e2e tests. Provides HTTP endpoints and commands to control your Laravel application during testing - manage databases, factories, authentication, migrations, and environment configuration from your Playwright tests.
Requirements
- PHP 8.3+
- Laravel 11+
Installation
composer require leeovery/laravel-playwright --dev
Publish config and register service provider:
php artisan playwright:install
Configuration
The package config (config/playwright.php) includes:
- Environments: Control which environments expose the endpoints (default:
local,testing,playwright) - Route prefix: Customize the endpoint URL prefix (default:
__playwright__) - Middleware: Set middleware for routes (default:
web) - Environment files: Configure
.playwright.envfile handling - Factory settings: Map model aliases and configure factory behaviors
Create a .playwright.env file for test-specific environment variables.
Features
HTTP Endpoints
All endpoints are prefixed with __playwright__ (configurable) and protected by environment checks:
Database Management
POST /create-database- Create test databasePOST /drop-database- Drop test databasePOST /migrate- Run migrations (supports?fresh=1&seed=1)POST /truncate- Truncate specific tables
Factory & Authentication
POST /factory- Create model instances via factoriesPOST /login- Authenticate user (create or find existing)POST /logout- End sessionPOST /user- Get current authenticated user
Utilities
POST /artisan- Execute artisan commandsPOST /routes- Get application route listGET /csrf- Get CSRF tokenPOST /env-setup- Swap to.playwright.envPOST /env-teardown- Restore original.env
Artisan Commands
# Setup/teardown test environment php artisan playwright:env-setup php artisan playwright:env-teardown # Database operations php artisan db:create --database=playwright_test php artisan db:drop --database=playwright_test
Usage Example
From Playwright tests, interact with Laravel via HTTP:
// Setup environment await request.post("http://localhost/__playwright__/env-setup"); // Run migrations await request.post("http://localhost/__playwright__/migrate", { data: { fresh: true, seed: true }, }); // Create and login user const user = await request.post("http://localhost/__playwright__/factory", { data: { model: "User", state: ["verified"], attributes: { email: "test@example.com" }, }, }); await request.post("http://localhost/__playwright__/login", { data: { attributes: { email: "test@example.com" } }, }); // Teardown await request.post("http://localhost/__playwright__/env-teardown");
Factory State Parameters
Pass complex state parameters to factories:
// Fetch model and pass to state method data: { state: [ { createdBy: ["model.User:100"] }, // Fetch User with id=100 ]; } // Use param aliases (configure in config/playwright.php) data: { state: [{ endsAt: ["Carbon(2023-12-25 23:59:59)"] }]; }
Register param aliases in your service provider:
use Leeovery\LaravelPlaywright\Playwright; Playwright::paramAlias('Carbon', fn($date) => new Carbon($date));
Security
Important: This package exposes powerful endpoints that can manipulate your application. Only enable in non-production environments. The package includes middleware that blocks requests outside configured environments.
If you discover security issues, email me@leeovery.com.
Testing
composer test
composer test-coverage
Development
# Format code with Pint composer pint # Refactor code with Rector composer rector
Credits
License
MIT License. See License File for details.