This has been customised from vijaycs85/drupal-quality-checker based on the Axelerant fork axelerant/drupal-quality-checker. Apart from a different template file, it uses the AxelerantDQCPlugin
to copy default configuration files as described below.
Upgrading from Beta 8? Read the instructions for changes you need to make to grumphp.yml.dist.
composer require --dev hotwebmatter/drupal-quality-checker
This will add the plugin to your project and copy the default configuration files. These files are:
grumphp.yml.dist
phpcs.xml.dist
phpmd.xml.dist
phpstan.neon.dist
Since these are .dist
files, the plugin will overwrite them on every composer install
. If you mean to customize the default settings, then we recommend that you rename them to remove the .dist
suffix. As such, it is a good idea to add these .dist
files to your .gitignore
file.
No additional steps required, but if git hooks aren't fired, run php ./vendor/bin/grumphp git:init
. For additional commands, look at grumhp's documentation.
Almost all customising begins with first copying the grumphp.yml.dist
file to your project. Make sure you have the file.
There are various tasks you can add and customise in your grumphp.yml. Read the online documentation for GrumPHP tasks to see the tasks you can use and configure.
To configure commit message structure, use the git_commit_message task. For example, to enforce the commit message contains the Jira issue ID, use the rule as the following snippet. More options are documented online.
# grumphp.yml
grumphp:
tasks:
git_commit_message:
matchers:
Must contain issue number: /JIRA-\d+/
GrumPHP supports banners to celebrate (or scold) on your commit. This is fun but it is possible it gets on your nerves. If you don’t want it, edit the grumphp.yml file and replace the following parameters:
# grumphp.yml
grumphp:
ascii: ~
You could even disable specific ones like this:
# grumphp.yml
grumphp:
ascii:
succeeded: ~
Copy the ruleset to the project root first
cp vendor/hotwebmatter/drupal-quality-checker/phpmd.xml.dist phpmd.xml
Edit it as per your needs and commit. Remember to modify the grumphp.yml file with the new path.
# grumphp.yml
grumphp:
tasks:
phpmd:
ruleset: ['phpmd.xml']
Copy the ruleset to the project root first
cp vendor/hotwebmatter/drupal-quality-checker/phpcs.xml.dist phpcs.xml
Edit it as per your needs and commit. Remember to modify the grumphp.yml file with the new path.
# grumphp.yml
grumphp:
tasks:
phpcs:
standard: ['phpcs.xml']
Copy the ruleset to the project root first
cp vendor/hotwebmatter/drupal-quality-checker/phpstan.neon.dist phpstan.neon
Edit it as per your needs and commit. Remember to modify the grumphp.yml file with the new path.
# grumphp.yml
grumphp:
tasks:
phpstan:
configuration: phpstan.neon
As described before, this package uses drupal/core-composer-scaffold
plugin to scaffold a few files to the project root. This is not required but there is a good chance you are already using it if you're building a Drupal site.
The scaffolding operation runs with every composer operation and overwrites files. Only the file grumphp.yml.dist
is not overwritten during subsequent operations. If you are customising any of the other configuration files and don't want the updates to overwrite your changes, you can override the behaviour in your composer.json file. For example, to skip phpmd.xml.dist
from being overwritten, add this to your composer.json
:
"name": "my/project",
...
"extra": {
"drupal-scaffold": {
"file-mapping": {
"[project-root]/phpmd.xml.dist": false
}
}
}
For more details, read the "Excluding Scaffold files" section of the documentation for the core-composer-scaffold plugin.