vstelmakh/covelyzer
最新稳定版本:v0.2.0
Composer 安装命令:
composer require vstelmakh/covelyzer
包简介
Tool to analyze PHPUnit test coverage report in clover format
README 文档
README
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
Installation
Install the latest version with Composer:
composer require --dev vstelmakh/covelyzer
Usage
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
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>
<covelyzer> element
Config root element.
timezone attribute
Timezone should be used to display timestamp.
- use:
optional - type:
string(see: php timezones) - command option: could be defined/overridden via
--timezonecommand option
<project> element
Defines configuration for project coverage report. If defined project coverage report will be rendered.
- parent:
<covelyzer> - use:
optional
minCoverage attribute
Minimum coverage value. If project have less coverage - report will fail.
- use:
required - type:
float(min: 0, max: 100)
<class> element
Defines configuration for class coverage report. If defined class coverage report will be rendered.
- parent:
<covelyzer> - use:
optional
minCoverage attribute
Minimum coverage value. If any class have less coverage - report will fail.
- use:
required - type:
float(min: 0, max: 100)
Tips & tricks
Use help option
Use -h | --help command option to display Covelyzer help data. It contains all available arguments, options and usage examples.
vendor/bin/covelyzer --help
Ignore code blocks
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.
Speed up coverage with Xdebug
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.
Credits
Volodymyr Stelmakh
Licensed under the MIT License. See LICENSE for more information.
统计信息
- 总下载量: 4.53k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 2
- 点击次数: 1
- 依赖项目数: 3
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2020-08-09