gotrendier/phpunit-coverage-check

Check the code coverage using the clover report of phpunit

Installs: 3 050

Dependents: 0

Suggesters: 0

Security: 0

Stars: 0

Watchers: 1

Forks: 0

Open Issues: 0

pkg:composer/gotrendier/phpunit-coverage-check

1.0.0 2023-06-12 09:44 UTC

This package is auto-updated.

Last update: 2025-09-30 12:18:55 UTC


README

Build Status

phpunit-coverage-check

This php script will read the clover xml report from phpunit and calculates the coverage score. Based on the given threshold the script will exit ok of the coverage is higher then the threshold or exit with code 1 if the coverage is lower then the threshold. This script can be used in your continuous deployment environment or for example added to a pre-commit hook.

Installation

The script can be installed using composer. Add this repository as a dependency to the composer.json file.

composer require --dev gotrendier/phpunit-coverage-check

Usage

The script has requires 2 parameters that are mandatory to return the code coverage.

  1. The location of the clover xml file, that's generated by phpunit.
  2. The coverage threshold that is acceptable. Min = 1, Max = 100

Generate the clover.xml file by using phpunit and run the coverage check script: Run the script:

vendor/bin/phpunit --coverage-clover clover.xml
vendor/bin/coverage-check clover.xml 80
vendor/bin/coverage-check clover.xml 80 app
vendor/bin/coverage-check clover.xml 80 --only-percentage
vendor/bin/coverage-check clover.xml 80 --only-percentage app

With the --only-percentage enabled, the CLI command will only return the resulting coverage percentage.

By default, chictrend folder will be measured. If you pass a folder like app after de percentage argument or--only-percentage argument that folder will be measured.

It's also possible to add the coverage report generation to the phpunit.xml.dist add to following line to the xml file:

<logging>
    <log type="coverage-clover" target="clover.xml"/>
</logging>

For more information see the phpunit documentation. Information about the configuration file and commandline options.