nimut/phpunit-merger

Merge multiple PHPUnit reports into one file

Maintainers

👁 IchHabRecht

Package info

github.com/Nimut/phpunit-merger

pkg:composer/nimut/phpunit-merger

Statistics

Installs: 1 783 519

Dependents: 6

Suggesters: 0

Stars: 50

Open Issues: 7

2.0.1 2024-08-05 08:33 UTC

Requires

Requires (Dev)

Suggests

Provides

None

Conflicts

None

Replaces

None

GPL-2.0+ ae4e968e677bfd3fda68000a9a304ae6965353e6

phpunitcoverageTYPO3 CMSsonarqube

This package is auto-updated.

Last update: 2026-06-05 12:22:55 UTC


README

👁 Latest Stable Version
👁 StyleCI
👁 GitHub Actions

Sometimes it is necessary to run multiple PHPUnit instances to execute all tests of a project. Unfortunately each run writes its own coverage and log reports. There is no support in PHPUnit to merge the reports of multiple runs.

This project provides two commands to merge coverage files as well as log files. It was designed to provide merged reports to e.g. SonarQube Scanner for further processing.

Installation

Use Composer to install the testing framework.

$ composer require --dev nimut/phpunit-merger

Composer will add the package as a dev requirement to your composer.json and install the package with its dependencies.

Usage

Coverage

The coverage command merges files containing PHP_CodeCoverage objects into one file in Clover XML format.

$ vendor/bin/phpunit-merger coverage <directory> [--html=<directory>] [<file>]

Arguments

  • directory: Directory containing one or multiple files with PHP_CodeCoverage objects
  • file: File where the merged result should be stored. Default: Standard output

Options

  • html: Directory where the HTML report should be stored
  • lowUpperBound: (optional) The lowUpperBound value to be used for HTML format
  • highLowerBound: (optional) The highLowerBound value to be used for HTML format

Log

The log command merges files in JUnit XML format into one file in JUnit XML format.

$ vendor/bin/phpunit-merger log <directory> <file>

Arguments

  • directory: Provides the directory containing one or multiple files in JUnit XML format
  • file: File where the merged result should be stored