Covelyzer - PHP console tool to analyze PHPUnit test coverage report in clover (XML) format. Covelyzer integrates coverage metrics directly into the workflow forcing developers to write tests and forbidding delivery of uncovered code.
Highlights:
- Works in console
- Easy to integrate
- Flexible configuration
- Same setup locally and on CI
- Not depend on third-party service
Install the latest version with Composer:
composer require --dev vstelmakh/covelyzer
Before you start, run tests with options to generate coverage report in XML format. See corresponding PHPUnit documentation reference Code coverage analysis and Covelyzer phpunit.xml, composer.json scripts section as an example.
Run tests with XML coverage xdebug example:
vendor/bin/phpunit --dump-xdebug-filter var/xdebug-filter.php && \
vendor/bin/phpunit --prepend var/xdebug-filter.php --coverage-clover var/coverage.xml --whitelist src
Run Covelyzer with default configuration:
vendor/bin/covelyzer var/coverage.xml
To specify additional configuration see Configuration.
Configuration defined in covelyzer.xml
located under project root (where vendor dir located). Or
configuration path could be overridden via -c | --config
command option:
vendor/bin/covelyzer var/coverage.xml -c path/to/covelyzer.xml
If no configuration file provided - default configuration is used.
Example configuration:
<?xml version="1.0" encoding="UTF-8" ?>
<covelyzer
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:noNamespaceSchemaLocation="vendor/vstelmakh/covelyzer/resources/config.xsd"
timezone="Europe/Berlin"
>
<project minCoverage="100"/>
<class minCoverage="100"/>
</covelyzer>
Config root element.
Timezone should be used to display timestamp.
- use:
optional
- type:
string
(see: php timezones) - command option: could be defined/overridden via
--timezone
command option
Defines configuration for project coverage report. If defined project coverage report will be rendered.
- parent:
<covelyzer>
- use:
optional
Minimum coverage value. If project have less coverage - report will fail.
- use:
required
- type:
float
(min: 0, max: 100)
Defines configuration for class coverage report. If defined class coverage report will be rendered.
- parent:
<covelyzer>
- use:
optional
Minimum coverage value. If any class have less coverage - report will fail.
- use:
required
- type:
float
(min: 0, max: 100)
Use -h | --help
command option to display Covelyzer help data. It contains all available arguments, options and usage examples.
vendor/bin/covelyzer --help
Covelyzer will analyze full report produced by PHPUnit. In some cases you want to ignore some code parts to not be taken into account. There are several options available, see Ignoring code blocks in PHPUnit documentation.
The performance of code coverage data collection with Xdebug can be improved by delegating whitelist filtering to Xdebug. See corresponding PHPUnit docs section: Speeding up code coverage with Xdebug.
Volodymyr Stelmakh
Licensed under the MIT License. See LICENSE for more information.