juampi92 / phecks
A package to run custom PHP checks
Installs: 193 082
Dependents: 0
Suggesters: 0
Security: 0
Stars: 4
Watchers: 2
Forks: 4
Open Issues: 0
Requires
- php: ^8.1|^8.2|^8.3
- ext-json: *
- illuminate/console: ^9.0|^10.0|^11.0
- illuminate/contracts: ^9.0|^10.0|^11.0
- illuminate/filesystem: ^9.0|^10.0|^11.0
- illuminate/support: ^9.0|^10.0|^11.0
- roave/better-reflection: ^6.25
Requires (Dev)
- friendsofphp/php-cs-fixer: ^3.13
- larastan/larastan: ^2.9
- orchestra/testbench: ^6.0|^7.0|^8.0|^9.0
- phpunit/phpunit: ^9.0|^10.5
README
Phecks
Phecks (stands for PHP-Checks) is a custom Check Runner. It will run custom checks in your codebase and will make a report of violations that need fixing.
What is it for?
- For big teams to align on a styleguide beyond linting.
- Used as an extra set of eyes during the Code Review.
- Teams make their own checks according to their architectural decisions and styleguides.
On its own, Phecks doesn't contain any checks. You and your team are responsible for defining and implementing these checks based on your architectural decisions.
Phecks will provide you with a structure to develop and run these checks easily.
Installation
You can install the package via composer:
composer require juampi92/phecks --dev
Read the full installation instructions in the documentation.
Usage
Create a Check to make sure your team's architectural decisions are respected:
/** * @implements Check<ReflectionClass> */ class ConsoleClassesMustBeSuffixedWithCommandCheck implements Check { public function __construct( private readonly ClassSource $source, ) {} /** * This method will get all the possible matches. */ public function getMatches(): MatchCollection { return $this->source ->directory('./app/Console') ->run() ->reject(fn (ReflectionClass $class): bool => $class->isAbstract()) ->pipe(new WhereExtendsClassFilter(\Illuminate\Console\Command::class)); } /** * processMatch will check if the matches are * actual violations, and format them properly. */ public function processMatch($match, FileMatch $file): array { if (Str::endsWith($match->getName(), 'Command')) { return []; } return [ ViolationBuilder::make()->message('Command classes must be suffixed with \'Command\''), ]; } }
Add the class in the config phecks.checks
And run the following:
php artisan phecks:run
Testing
composer test
Credits
License
The MIT License (MIT). Please see License File for more information.