Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Introduce merge_junit script #103

Merged
merged 8 commits into from
Aug 5, 2024
Merged
Show file tree
Hide file tree
Changes from 5 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@ _None._

### New Features

_None._
- Introduce `merge_junit` script [#103]
wzieba marked this conversation as resolved.
Show resolved Hide resolved

### Bug Fixes

Expand Down
43 changes: 43 additions & 0 deletions bin/merge_junit
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nitpick: I'd recommend naming this script merge_junit_reports instead, to make it clearer that we're not trying to merge the Unit Tests themselves somehow (?), but just the report files 😛

Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
#!/bin/bash

# Initialize variables
reports_dir=""
output_file=""

# Function to show usage
usage() {
echo "Usage: $0 -d <reports_dir> -o <output_file>"
exit 1
}

# Parse command-line options
while getopts "d:o:" opt; do
case $opt in
d) reports_dir=$OPTARG ;;
o) output_file=$OPTARG ;;
?) usage ;;
esac
done

# Check if both arguments were provided
if [ -z "$reports_dir" ] || [ -z "$output_file" ]; then
usage
fi

touch "$output_file"
{
echo '<?xml version="1.0" encoding="UTF-8"?>'
# Write XML header to the output file
echo '<testsuites>'

# Merge the content of all input JUnit files in the directory.
# (Note that in the case of Unit Tests, the JUnit XML files produced by Gradle
# don't have a parent `<testsuites>` root tag, so there's no need to try and remove it)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

While I was ok with this assumption being held for WooCommerce where you initially implemented this, now that this is going to become a broader utility for more repositories to use, I feel like we should be more careful in our implementation and assumptions here, especially to make sure we support cases and other projects where such assumption might not be always true 🤔

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What do you suggest? I think this is a standard behavior of JUnit working with Android Gradle Plugin - there's nothing specific in WooCommerce Android.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

My only fear is that someone would be tempted to use this merge_junit_report utility also on JUnit reports that don't come from Unit Tests created by Android Gradle Plugin, like JUnit reports created by fastlane, or by other wrappers (e.g. maybe electron-builder when building the Android app of an Electron codebase?), or for test reports that are also in the JUnit format but for tests other than Unit tests (e.g. UI Tests / E2E Tests?).
If it happens that those other reports, despite being in the JUnit format, don't fit the assumption that this merge_junit_reports utility makes of them not being wrapped within <testsuites> root node because they are generated by another tool than Android Gradle Plugin for Unit Tests, then this will break the merged file that it generates.

By contrast, just adjusting the sed pattern to remove those <testsuites> root elements if they happen to be present in the input file doesn't seem like something too complex to add (iirc I even suggested a pattern for it in the WCAndroid PR where you introduced that script initially) while making this merge_junit_reports utility more resilient and less likely to create invalid XML files.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Gotcha 👍 I've added a logic to ignore <testsuites> tag in reports that are being merged. WDYT? 1913f43

I've tried to add a test for this with bats, but surprisingly it happened to be quite unstable even with a simple test - occasionally it was ending in a state, that was simply not finishing a test. After killing the process and running test again all worked fine. I didn't want to introduce flakiness though.

sed '/<\?xml .*\?>/d' "$reports_dir"/*.xml

# Close the testsuites tag
echo '</testsuites>'
} >> "$output_file"

# Print the result
echo "Merged XML reports into $output_file"