This library adds a custom report to PHP_CodeSniffer (phpcs) to generate a codequality artifact that can be used by GitLab CI/CD. The custom report is generated in Code Climate format and allows GitLab CI/CD to display the violations in the Code Quality report.
Install this library using Composer:
composer require --dev micheh/phpcs-gitlab
Then adjust your .gitlab-ci.yml
to run PHP_CodeSniffer with the custom reporter and to collect the codequality artifacts:
phpcs:
script: vendor/bin/phpcs --report=full --report-\\Micheh\\PhpCodeSniffer\\Report\\Gitlab=phpcs-quality-report.json
artifacts:
reports:
codequality: phpcs-quality-report.json
The example above uses two reports, one to display in the build log (full) and one to generate the codequality artifact file in Code Climate format.
Note: GitLab did not support multiple codequality artifacts before version 15.7. If you are using an earlier version of GitLab, you will not be able to see the violations from multiple tools (e.g. PHP Code Sniffer & PHPStan) in the Code Quality report.
Inside the codequality artifact, GitLab expects relative paths to the files with violations.
To generate relative paths with PHP Code Sniffer, set the basepath
argument in your phpcs.xml.dist
configuration file with <arg name="basepath" value="."/>
or run phpcs with --basepath=.
(adjust the base path as needed).
It is also possible to specify the reports to be used in the phpcs.xml.dist
file:
<arg name="report" value="full"/>
<arg name="report-\Micheh\PhpCodeSniffer\Report\Gitlab" value="phpcs-quality-report.json"/>
The usage of this package remains the same. However, the calculation of the fingerprint has been updated and is now based on the content instead of the line number. This has the advantage that lines with violations can move up or down and GitLab will not report them as new violations. When upgrading to version 2, it is likely that all violations will show up as changed once, since all fingerprints are new.
The files in this archive are licensed under the BSD-3-Clause license. You can find a copy of this license in LICENSE.md.