This repository demonstrates using the Develocity API and generating client code from its OpenAPI specification.
The sample contains two scenarios:
- The
builds
scenario observes builds being published to the given Develocity instance in real-time and prints basic attributes along with build cache performance metrics. - The
tests
scenario determines previously stable test classes that have recently become unstable, and creates a report pointing to example builds published to the given Develocity instance.
Execute:
$ ./gradlew install
This builds and installs the program into build/install/develocity-api-samples
.
You can use the build/install/develocity-api-samples/bin/develocity-api-samples
script to run the sample.
The current version of the OpenAPI generator requires Java 11 to generate the client code. Even though this sample uses Java 11 to generate the client, but the generated client code is based on Java 8. Therefore, the generated client is still compatible with Java 8 based projects.
A Develocity access key with the “Export build data via the API” permission is required.
To create an access key:
- Sign in to Develocity.
- Access "My settings" from the user menu in the top right-hand corner of the page.
- Access "Access keys" from the left-hand menu.
- Click "Generate" on the right-hand side and copy the generated access key.
The access key should be saved to a file, which will be supplied as a parameter to the program.
After provisioning the access key, execute:
$ build/install/develocity-api-samples/bin/develocity-api-samples builds --server-url=«serverUrl» --access-key-file=«accessKeyFile» --project-name=«projectName»
«serverUrl»
: The address of your Develocity server (e.g.https://develocity.example.com
)«accessKeyFile»
: The path to the file containing the access key«projectName»
(optional): The name of the project to limit reporting to (reports all builds when omitted)«reverse»
(optional): A boolean indicating the time direction of the query. A value of true indicates a backward query. A value of false indicates a forward query (default: false).«maxBuilds»
(optional): The maximum number of builds to return by a single query. The number may be lower if --max-wait-secs is reached (default - 100)«maxWaitSecs»
(optional): The maximum number of seconds to wait until a query returns. If the query returns before --max-builds is reached, it returns with already processed builds (default - 3)
The program will print Processing builds ...
, then:
- when not using
--reverse
or using--reverse=false
: indefinitely listen for any new builds being published to Develocity and print basic information about each build to the console. - when using
--reverse
or--reverse=true
: listen for all builds that were already published to Develocity and print basic information about each build to the console.
To stop the program, use Ctrl + C.
After provisioning the access key, execute:
$ build/install/develocity-api-samples/bin/develocity-api-samples tests --server-url=«serverUrl» --access-key-file=«accessKeyFile» [--project-name=«projectName»] [--reporter-type=<<reporterType>>] [--github-repo=<<githubRepo>>]
«serverUrl»
: The address of your Develocity server (e.g.https://ge.example.com
)«accessKeyFile»
: The path to the file containing the access key«projectName»
(optional): The name of the project to limit reporting to (reports unstable containers from all projects when omitted)«reporterType»
(optional): The type of the report to be generated for discovered unstable containers (possible values:STANDARD_OUTPUT
orGITHUB_CLI
). TheGITHUB_CLI
type requires the GitHub CLI to be installed on your machine.«githubRepo»
(optional): The URL of the GitHub repo to create issues in. Required if the reporter type is set toGITHUB_CLI
.
The program will:
- Determine a set of test containers which were unstable (i.e. failed or flaky) in the past 7 days.
- Determine a set of test containers which became unstable just yesterday.
- Fetch additional data for such containers like builds and test tasks/goals where the container was unstable, as well as the list of unstable cases.
- Report the summary of findings to the standard output or create issues in the GitHub repository of your choice.
To stop the program, use Ctrl + C.
The sample code can be found here.
The Develocity API manual and reference documentation for each version of the API can be found here.
The Develocity API Samples project is open-source software released under the Apache 2.0 License.