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.
- PHP 8.3+
- Laravel 11+
composer require leeovery/laravel-playwright --devPublish config and register service provider:
php artisan playwright:installThe 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.
All endpoints are prefixed with __playwright__ (configurable) and protected by environment checks:
POST /create-database- Create test databasePOST /drop-database- Drop test databasePOST /migrate- Run migrations (supports?fresh=1&seed=1)POST /truncate- Truncate specific tables
POST /factory- Create model instances via factoriesPOST /login- Authenticate user (create or find existing)POST /logout- End sessionPOST /user- Get current authenticated user
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
# 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_testFrom 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: "[email protected]" },
},
});
await request.post("http://localhost/__playwright__/login", {
data: { attributes: { email: "[email protected]" } },
});
// Teardown
await request.post("http://localhost/__playwright__/env-teardown");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));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 [email protected].
composer test
composer test-coverage# Format code with Pint
composer pint
# Refactor code with Rector
composer rectorMIT License. See License File for details.