stateforge/scenario-laravel
最新稳定版本:1.1.0
Composer 安装命令:
composer require --dev stateforge/scenario-laravel
包简介
Laravel adapter for Stateforge Scenario Core – declarative, attribute-driven scenario execution for reproducible application state.
README 文档
README
Scenario Laravel
Laravel integration for Stateforge Scenario Core.
This package provides framework-specific integration for Laravel applications, enabling seamless scenario execution within PHPUnit tests and Artisan workflows.
It builds on top of stateforge/scenario-core and integrates with the Laravel container,
Artisan console, and testing environment.
Requirements
Scenario Laravel requires the following:
- PHP >= 8.2
- Laravel 12+
- stateforge/scenario-core
Installation
This package is intended for local, develop and testing use only.
composer require --dev stateforge/scenario-laravel
After installation, run the setup command:
php artisan scenario:install
The installation command generates the required configuration files:
- creates
scenario/bootstrap.phpfor runtime bootstrapping - generates
scenario.dist.xmlfor configuration - places the extension into
phpunit.xmlorphpunit.dist.xml
What This Package Provides
Scenario Laravel integrates Scenario Core with:
- Laravel’s service container
- Laravel Artisan console
- Laravel application lifecycle
- PHPUnit integration
Service Provider
The package automatically registers its service provider.
It handles:
- registering console commands
- wiring scenario services
- integrating the Scenario runtime with Laravel
Database Reset
When using #[RefreshDatabase], the Laravel integration resets the database
using Laravel’s migration system.
The default behavior:
- runs
migrate:fresh - optionally supports connection-specific resets
Applying Scenarios in Unit Tests
Scenarios can be applied declaratively using the #[ApplyScenario] attribute:
use Stateforge\Scenario\Core\Attribute\ApplyScenario; #[ApplyScenario('my-scenario')] final class MyTest extends TestCase { #[ApplyScenario('my-second-scenario')] public function testSomethingImportant(): void { // scenario has already been applied, data can be tested } }
Console Commands
Scenario Laravel registers dedicated Artisan commands within your application.
You can discover them using:
php artisan list scenario
Available commands include:
scenario:list– List available scenariosscenario:apply– Apply a scenario manuallyscenario:debug– Debug scenarios or unit testsscenario:make– Generate a new scenarioscenario:install– Install Scenario into the project
Environment Restrictions
Scenario commands are intended for local, development and testing environments only.
By default, they are restricted to:
localdeveloptesting
This can be configured via:
config('scenario.allowed_envs');
Next Steps
统计信息
- 总下载量: 2
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 6
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: BSD-3-Clause
- 更新时间: 2026-04-04
