sweetchuck / junit-merger-cli
CLI tool to merge two or more JUnit XML files into one.
Installs: 2 736
Dependents: 1
Suggesters: 0
Security: 0
Stars: 1
Watchers: 1
Forks: 1
Open Issues: 1
Type:project
pkg:composer/sweetchuck/junit-merger-cli
Requires
- php: >=8.4
- ext-json: *
- psr/log: ^3.0
- sweetchuck/junit-merger: 2.x-dev
- symfony/console: ^7.0
- symfony/dependency-injection: ^7.0
Requires (Dev)
- ext-dom: *
- mikey179/vfsstream: ^1.6
- nuvoleweb/robo-config: ^3.0
- phpstan/extension-installer: ^1.4
- phpstan/phpstan: ^2.1
- phpstan/phpstan-phpunit: ^2.0
- phpunit/phpunit: ^11.0
- squizlabs/php_codesniffer: ^4.0
- sweetchuck/git-hooks: 2.x-dev
- sweetchuck/robo-composer: 4.x-dev
- sweetchuck/robo-git: 4.x-dev
- sweetchuck/robo-phpcs: 4.x-dev
- sweetchuck/robo-phpstan: 3.x-dev
- symfony/error-handler: 7.0
- symfony/finder: ^7.0
- symfony/yaml: ^7.0
This package is auto-updated.
Last update: 2025-10-20 16:18:31 UTC
README
As the name suggests this CLI tool helps to merge two or more JUnit XML files into one. 
Under the hood it uses the JUnit merger library.
Usage
By default it reads the input file names from stdIn line by line, and puts the result XML content to the stdOutput. 
So the basic usage:
find path/to/junit -type f -name '*.xml' | junit-merger merge:files
The input file names also can be provided as arguments. Like this:
junit-merger merge:files 1.xml 2.xml
The merged XML content can be put into a file by using standard shell redirections. Like this:
junit-merger merge:files 1.xml 2.xml > junit.xml
Or by using the --output-file CLI option. Like this:
junit-merger merge:files --output-file='junit.xml' 1.xml 2.xml
Usage - handlers
Handlers are responsible for read and parse the input files and generate the merged XML content. 
To which handler should be used can be controlled by the --handler option. Like this:
junit-merger merge:files --handler='dom_read_write' 1.xml 2.xml
There are three available option
Usage - handler - dom_read_write
With this handler the input files are parsed with \DOMDocument and the output is also generated with it. 
It is safe and reliable, but resource heavy. 
On the other hand this handler recalculates all the <testsuite tests assertions errors warnings failures skipped time /> attributes. 
This might come handy when multiple <testcase /> comes from different input files and they are belong to the same <testsuite />.
Usage - handler - dom_read
With this handler the input files are parsed with \DOMDocument and the output is generated with string concatenation.
Usage - handler - substr
The input files have to be in the same format in the terms of the position of the opening <testsuites> tag and the closing </testsuites> tag. 
These position parsed from the first input file and the same positions will be used for the remaining input files. 
Usually the input files are come from the same source – for example PHPUnit – so their format is identical.