A Buildkite plugin for uploading JSON or JUnit files to Buildkite Test Analytics ✨
These are all the options available to configure this plugin's behaviour.
One or more patterns of files to upload to Test Analytics, relative to the root of the searching path (./
by default). May contain *
to match any number of characters of any type (unlike shell expansions, it will match /
and .
if necessary). Can be either a single pattern in a string or any number of them in an array.
Format of the file.
Only the following values are allowed: junit
, json
Name of the environment variable that contains the Test Analytics API token.
Default value: BUILDKITE_ANALYTICS_TOKEN
Full URL for the API to upload to. Defaults to https://analytics-api.buildkite.com/v1/uploads
Where to search for files to upload. Defaults to the working directory .
String containing a regex to only do an upload in branches that match it (using the case-insensitive bash =~
operator against the BUILDKITE_BRANCH
environment variable).
For example:
prod
will match any branch name that contains the substringprod
^stage-
will match all branches that start withstage-
-ISSUE-[0-9]*$
will match branches that end withISSUE-X
(where X is any number)
Important: you may have to be careful to escape special characters like $
during pipeline upload
Print debug information to the build output.
Default value: false
.
Can also be enabled with the environment variable BUILDKITE_ANALYTICS_DEBUG_ENABLED
.
String containing a regex avoid doing an upload in branches that match it (using the case-insensitive bash =~
operator against the BUILDKITE_BRANCH
environment variable ).
For example:
prod
will exclude any branch name that contains the substringprod
^stage-
will exclude all branches that start withstage-
-SECURITY-[0-9]*$
will exclude branches that end withSECURITY-X
(where X is any number)
Important:
- you may have to be careful to escape special characters like
$
during pipeline upload - exclusion of branches is done after the inclusion (through the
branches
option)
By default the plugin will not follow symlinked folders, set this option to true
to do so. This will add the -L
option to the find
command used to get the files to upload.
Exit code of the hook when no files are found to upload as long as the step's command has not failed already.
This should allow you to use a special exit code to soft-fail on when no files to upload. Warning: make sure that the exit code used can not be generated by your command to avoid hiding actual step failures.
Default value: 1
Maximum number of seconds to wait for each file to upload before timing out.
Default value: 30
Adds an annotation to the build run with a link to the uploaded report.
Default value: false
The number of concurrent file uploads to perform to the Buildkite analytics API.
Default value: 1
This plugin requires jq
for parsing JSON data. If jq
is not found on the agent, sed
will be used as a fallback. Ensure that sed
is also available to handle scenarios where jq
cannot be used.
If jq
is unavailable, the plugin will attempt to parse the results using sed
. This ensures that the plugin remains functional even if the preferred JSON parser is missing.
To upload a JUnit file to Test Analytics from a build step:
steps:
- label: "🔨 Test"
command: "make test"
plugins:
- test-collector#v1.10.1:
files: "test/junit-*.xml"
format: "junit"
To upload a JSON file to Test Analytics from a build step:
steps:
- label: "🔨 Test"
command: "make test"
plugins:
- test-collector#v1.10.1:
files:
- "test-data-*.json"
format: "json"
You can also use build artifacts generated in a previous step:
steps:
# Run tests and upload
- label: "🔨 Test"
command: "make test --junit=tests-N.xml"
artifact_paths: "tests-*.xml"
- wait
- label: "🔍 Test Analytics"
command: buildkite-agent artifact download "tests-*.xml" .
plugins:
- test-collector#v1.10.1:
files: "tests-*.xml"
format: "junit"
Only upload on the branches that end with -qa
steps:
- label: "🔨 Test"
command: "make test"
plugins:
- test-collector#v1.10.1:
files: "test-data-*.json"
format: "json"
branches: "-qa$"
Do not upload on the branch that is exactly named legacy
:
steps:
- label: "🔨 Test"
command: "make test"
plugins:
- test-collector#v1.10.1:
files: "test-data-*.json"
format: "json"
exclude-branches: "^legacy$"
Only upload on branches that start with stage-
but do not contain hotfix
steps:
- label: "🔨 Test"
command: "make test"
plugins:
- test-collector#v1.10.1:
files: "test-data-*.json"
format: "json"
branches: "^stage-"
exclude-branches: "hotfix"
You can use the bk cli to run the pipeline locally:
bk local run
Or if you want to run just the tests, you can use the docker Plugin Tester:
docker run --rm -ti -v "${PWD}":/plugin buildkite/plugin-tester:latest
Bug reports and pull requests are welcome on GitHub at https://github.com/buildkite-plugins/test-collector-buildkite-plugin
The package is available as open source under the terms of the MIT License.