17 releases

0.1.18 Jul 9, 2024
0.1.17 Sep 22, 2022
0.1.15 Apr 3, 2022
0.1.14 Jan 16, 2022
0.1.8 Sep 25, 2021

#188 in Development tools

Download history 187/week @ 2024-08-02 163/week @ 2024-08-09 95/week @ 2024-08-16 258/week @ 2024-08-23 328/week @ 2024-08-30 371/week @ 2024-09-06 246/week @ 2024-09-13 509/week @ 2024-09-20 242/week @ 2024-09-27 227/week @ 2024-10-04 270/week @ 2024-10-11 201/week @ 2024-10-18 231/week @ 2024-10-25 268/week @ 2024-11-01 215/week @ 2024-11-08 186/week @ 2024-11-15

925 downloads per month

MIT license

59KB
1.5K SLoC

junitify

junitify on crates.io pipeline

junitify takes JSON tests from stdin and writes JUnit XML results into stdout, or into a directory specified with --out.

This can be used to integrate with CI/CD platforms that uses JUnit XML format to show tests results in the UI, such as Gitlab.

Installation

cargo install junitify

Example

cargo test -- --format=json -Z unstable-options --report-time | junitify --out tests/

Valgrind (Since 0.1.13)

Since 0.1.13 you can transform Valgrind XML report into JUnit reports, for example:

fish.shell

valgrind --tool=memcheck --xml=yes --xml-file=report.xml (cargo +nightly test -q --message-format=json --no-run | jq -r '.executable | select(. != null)')
junitify -k valgrind --out tests/ -f report.xml

Non-Zero exit code (Since 0.1.14)

Since 0.1.14, you can now use -z to make junitify exit with a non-zero code when tests fail, also you can use -r to report all tests to stdout.

JUnit XML (Since 0.1.14)

Since 0.1.14, junitify is able to read the JUnit XML produced by itself, in companion with -z and -r, it will print tests results and exit with a non-zero code when there are failed tests.

JUnit XML parser works in the same way as the other parsers, it reads JUnit XML and outputs JUnit XML, it may change its contents and structure, and remove a bunch of values (in case of XMLs that were not generated by junitify).

New XML generator (Since 0.1.14)

Instead of using Handlebars, we now use quick-xml to generate XML, this will help with preserving the original output of tests without applying strange indentation, at the same time it provides a more maintainable code based more on serde.

We will be removing the handlebars dependency in the future (removed in 0.1.15).

Ignore parsing errors (Since 0.1.15)

Sometimes, the tests prints messages to the Stdout and Stderr, and they are piped to the Cargo output, mixing with the test suite output, this causes junitify to fail when parsing the output. To overcome this, you can use -i or --ignore-parse-errors to ignore parsing errors.

Be aware that, if the Cargo output json format changes (and it will, since --format=json is unstable), the junitify will ignore them instead of crashing, so only use it when your tests output are messing with the output of cargo test.

Example with -i:

cargo test -- --format=json -Z unstable-options --report-time | junitify -i --out tests/

Read the full changelog here Junitify 0.1.15 Changelog

CI/CD Docker Image (deprecated)

The docker image is deprecated, Rust now provides a nightly image, therefore junitify does not build its own images any more (which I neglected and was not useful for a long time anyway).

CI/CD Example

Outdated

You can find an example of CI/CD usage in bindet .gitlab-ci.yml, and see how they look like in one of the pipeline reports.

How it should be done now

You can take a look at tomq CI/CD example for a more up-to-date example. You may also want to pin a specific version:

cargo +nightly install junitify@0.1.17

If you don't want to build junitify every time, take a look at junitify packages on GitLab, there you can find the latest binary version of junitify (only for Linux x86 for now, arm64 coming soon as GitLab added arm64 machines).

Just make sure to validate the checksums on your CI/CD pipeline for the sake of security.

Dependencies

~8–19MB
~212K SLoC