kishieel / laravel-form-request-unit
Laravel Form Request Unit Test Helper
Installs: 117
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
pkg:composer/kishieel/laravel-form-request-unit
Requires
- php: ^7.3|^8.0
- illuminate/contracts: ^7.0|^8.0
- illuminate/support: ^7.0|^8.0
- illuminate/validation: ^7.0|^8.0
Requires (Dev)
- friendsofphp/php-cs-fixer: ^2.9|^3.3
- marcocesarato/php-conventional-changelog: ^1.12
- orchestra/testbench: ^4.0|^5.0|^6.0
- pestphp/pest: ^1.21
- phpunit/phpunit: ^8.0|^9.3
This package is auto-updated.
Last update: 2025-12-09 19:05:42 UTC
README
Helpers for laravel form request unit testing. It allows you to keep your controller tests clean and focus on testing their proper purpose by taking form request assertions to separate tests.
Installation
You can install the package via composer:
composer require --dev kishieel/laravel-form-request-unit
Usage
Rules Validation
With FormRequestValidator trait you may test your FormRequest without direct request to controller. Mentioned trait
provide validate method which takes FormRequest and data which should be validated as arguments.
use Kishieel\RequestUnit\FormRequestValidator; public function some_example_test() { $formRequest = new YourFormRequest(); $data = [ 'property_1' => 12, 'property_2' => 'string' ]; $result = $this->validate($formRequest, $data); // .. }
As a result you will get ValidatorResponse which provide passes and errors methods. First method allow you to
determinate whether data passes validation against form request rules. Second method may be used when you expected
validation fail and want to determinate whether data failed against expected rule.
use Kishieel\RequestUnit\FormRequestValidator; public function some_example_test() { // .. $this->assertFalse($result->passes()); $this->assertArrayHasKey('property_3', $result->errors()); }
Selective Validation
With a very complex FormRequest, you may want to test data against only specified rules. You may achieve this by
passing array of rule keys as third parameter of validate method.
use Kishieel\RequestUnit\FormRequestValidator; public function some_example_test() { // .. $result = $this->validate($formRequest, $data, ['property_1']); // will keep errors only for `property_1` $result->errors(); }
Authorization Validation
With FormRequestValidator you may validate FormRequest authorization method. Result will be available via
passes method on validation result.
Testing Custom Validation Rules
In case of custom validation rules you may use FormRequestCreator to create FormRequest on runtime and test it
against your data. FormRequestCreator takes rules array and authorization callback as constructor arguments. Arguments
are optional. You may use setRules and setAuthorization methods if you prefer.
Validator::extend('mac_address', function ($attribute, $value) { return preg_match('/^([0-9A-Fa-f]{2}[:-]){5}([0-9A-Fa-f]{2})$/', strval($value)); });
use Kishieel\RequestUnit\FormRequestValidator; public function some_example_test() { $formRequest = new \Kishieel\RequestUnit\FormRequestCreator([ 'mac_address' => 'required|mac_address' ]); $result = $this->validate($formRequest, ['mac_address' => 'invalid_mac_address']); $this->assertFalse($result->passes()); $this->assertArrayHasKey('mac_address', $result->errors()); }
Contributing
Before any pull request to master branch please run cs fixer and unit test.
composer fix
composer test
Changelog
Please see CHANGELOG for more information on what has changed recently.
License
The MIT License (MIT). Please see License File for more information.