magician79/php-coverage-tools
最新稳定版本:v0.2.1
Composer 安装命令:
composer require --dev magician79/php-coverage-tools
包简介
CLI tools for normalizing PHP coverage reports by removing non-executable files
README 文档
README
Small, explicit CLI utilities for normalizing PHP coverage reports.
Why
Cobertura and similar coverage formats correctly include interfaces and pure contracts in their reports. These elements contain no executable code.
Many coverage summary tools, however, treat these entries as 0% covered files, which pollutes coverage metrics and causes misleading regressions.
This package enforces a simple rule:
Non-executable code must not affect coverage health.
Tooling
filter-cobertura
Filters non-executable packages from a Cobertura XML report.
A package is considered non-executable when all of the following are true:
line-rateis0complexityis0- It contains no executable
<line>elements - It represents an empty
<classes/>structure (typical for interfaces)
This logic matches Cobertura output observed in real-world reports and is validated by unit tests.
Executable packages and mixed packages (for example, partially covered code) are preserved defensively.
Usage
filter-cobertura input.xml output.xml
The resulting file contains only executable coverage data and can safely be used for coverage summaries, CI thresholds, and badges.
If a non-executable package leaks through after filtering, the tool fails fast with a clear error instead of silently producing incorrect metrics.
Guarantees
- Executable packages are never removed
- Mixed or ambiguous packages are preserved
- Pure non-executable packages are excluded
- Behavior is enforced by unit tests
Installation
Install as a development dependency:
composer require magician79/php-coverage-tools
This package is intended for CI and development workflows and should not be installed in production dependencies.
Typical CI usage
vendor/bin/filter-cobertura \ coverage/cobertura.xml \ coverage/cobertura.filtered.xml
Use the filtered report for coverage summaries and badges.
License
MIT
统计信息
- 总下载量: 14
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2025-12-26