定制 leeovery/laravel-playwright 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

leeovery/laravel-playwright

最新稳定版本:v0.3.0

Composer 安装命令:

composer require leeovery/laravel-playwright

包简介

Backend stuff for Playwright e2e tests

README 文档

README

Latest Version on Packagist Total Downloads GitHub Actions

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.env file 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 database
  • POST /drop-database - Drop test database
  • POST /migrate - Run migrations (supports ?fresh=1&seed=1)
  • POST /truncate - Truncate specific tables

Factory & Authentication

  • POST /factory - Create model instances via factories
  • POST /login - Authenticate user (create or find existing)
  • POST /logout - End session
  • POST /user - Get current authenticated user

Utilities

  • POST /artisan - Execute artisan commands
  • POST /routes - Get application route list
  • GET /csrf - Get CSRF token
  • POST /env-setup - Swap to .playwright.env
  • POST /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.

统计信息

  • 总下载量: 176
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 8
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 8
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2022-12-26

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固