A developer tool which provides a pre-defined GrumPHP configuration tailored specifically for PHP development at European Commission.
This package has been inspired by drupol/php-conventions and ergebnis/php-library-template.
Based on GrumPHP, this tool will run a set of quality control tools via a git hook. The user is free to disable the git hook and run the tool manually instead, see the documentation to know more about that.
The default GrumPHP configuration ships with the following checks:
- License file creation (BSD-3-Clause by default),
- Composer Require Checker,
- composer.json validation,
- composer.json normalization,
- YAML Lint,
- JSON Lint,
- PHP Lint,
- Twig CS,
- PHP CS Fixer checks (Based on PSR12),
- PHP CS,
- PHPStan.
- Psalm.
It provides a default configuration for each task, and they are customizable at will through a simple YAML configuration file.
Tasks can be also added or skipped according to your needs.
composer require ecphp/php-conventions --devAdd or edit the file grumphp.yml.dist or grumphp.yml and add on the top it:
imports:
- { resource: vendor/ecphp/php-conventions/config/php73/grumphp.yml }Replace the string php73 with the minimal version of PHP you want to support.
Current choices are:
psr12php73php74(Not available yet)
You may configure everything from that file.
To add an extra task or skip a task:
imports:
- { resource: vendor/ecphp/php-conventions/config/php73/grumphp.yml }
parameters:
extra_tasks:
phpunit: ~
skip_tasks:
- phpstanTo edit the configuration of a particular existing task
imports:
- { resource: vendor/ecphp/php-conventions/config/php73/grumphp.yml }
parameters:
tasks.license.holder: <License holder here>
tasks.license.name: BSD-3-Clause # MIT and EUPL-1.2 are also available
tasks.license.date_from: 2019Find all the available customizable properties in the imported file on the top of the YAML file.
vendor/bin/grumphp runThis will run all the pre-configured tasks.
If you're willing to specify a group of tasks only, you can use the pre-defined test suites.
Available test-suites are:
cs- license
- composer_require_checker
- composer
- composer_normalize
- yamllint
- jsonlint
- phplint
- twigcs
- phpcsfixer
- phpcs
static-analysis- phpstan
- psalm
To run a particular test-suite:
vendor/bin/grumphp run --testsuite=csTo run particular tasks:
vendor/bin/grumphp run --tasks=phpcsfixer,phpcsReport bug on the issue tracker.
See the file CONTRIBUTING.md but feel free to contribute to this library by sending Github pull requests.
See CHANGELOG.md for a changelog based on git commits.
For more detailed changelogs, please check the release changelogs.