stateforge / scenario-laravel
Laravel adapter for Stateforge Scenario Core – declarative, attribute-driven scenario execution for reproducible application state.
Requires
- php: >=8.2
- laravel/framework: ^12.0
- stateforge/scenario-core: ^1.0
- symfony/process: ^7.0
Requires (Dev)
- friendsofphp/php-cs-fixer: ^3.60
- mockery/mockery: ^1.6
- phpstan/phpstan: ^2.1
- phpstan/phpstan-strict-rules: ^2.0
- phpunit/phpunit: ^11.0
README
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');