mirror of
https://github.com/gradle/actions
synced 2024-11-27 11:52:24 +00:00
77 lines
3.9 KiB
YAML
77 lines
3.9 KiB
YAML
name: Gradle Dependency Submission
|
|
description: Generates a dependency graph for a Gradle project and submits it via the Dependency Submission API
|
|
|
|
inputs:
|
|
gradle-version:
|
|
description: |
|
|
Gradle version to use. If specified, this Gradle version will be downloaded, added to the PATH and used for invoking Gradle.
|
|
If not provided, it is assumed that the project uses the Gradle Wrapper.
|
|
required: false
|
|
build-root-directory:
|
|
description: Path to the root directory of the build. Default is the root of the GitHub workspace.
|
|
required: false
|
|
cache-encryption-key:
|
|
description: |
|
|
A base64 encoded AES key used to encrypt the configuration-cache data. The key is exported as 'GRADLE_ENCRYPTION_KEY' for later steps.
|
|
A suitable key can be generated with `openssl rand -base64 16`.
|
|
Configuration-cache data will not be saved/restored without an encryption key being provided.
|
|
required: false
|
|
dependency-graph:
|
|
description: |
|
|
Specifies how the dependency-graph should be handled by this action. By default a dependency-graph will be generated and submitted.
|
|
Valid values are:
|
|
'generate-and-submit' (default): Generates a dependency graph for the project and submits it in the same Job.
|
|
'generate-and-upload': Generates a dependency graph for the project and saves it as a workflow artifact.
|
|
'download-and-submit': Retrieves a previously saved dependency-graph and submits it to the repository.
|
|
|
|
The `generate-and-upload` and `download-and-submit` options are designed to be used in an untrusted workflow scenario,
|
|
where the workflow generating the dependency-graph cannot (or should not) be given the `contents: write` permissions
|
|
required to submit via the Dependency Submission API.
|
|
required: false
|
|
default: 'generate-and-submit'
|
|
additional-arguments:
|
|
description: |
|
|
Additional arguments to pass to Gradle. For example, `--no-configuration-cache --stacktrace`.
|
|
required: false
|
|
|
|
build-scan-publish:
|
|
description: |
|
|
Set to 'true' to automatically publish build results as a Build Scan on scans.gradle.com.
|
|
For publication to succeed without user input, you must also provide values for `build-scan-terms-of-service-url` and 'build-scan-terms-of-service-agree'.
|
|
required: false
|
|
default: false
|
|
build-scan-terms-of-service-url:
|
|
description: The URL to the Build Scan® terms of service. This input must be set to 'https://gradle.com/terms-of-service'.
|
|
required: false
|
|
build-scan-terms-of-service-agree:
|
|
description: Indicate that you agree to the Build Scan® terms of service. This input value must be "yes".
|
|
required: false
|
|
|
|
runs:
|
|
using: "composite"
|
|
steps:
|
|
- name: Generate dependency graph
|
|
if: ${{ inputs.dependency-graph == 'generate-and-submit' || inputs.dependency-graph == 'generate-and-upload' }}
|
|
uses: gradle/actions/setup-gradle@v3.0.0
|
|
with:
|
|
dependency-graph: ${{ inputs.dependency-graph }}
|
|
dependency-graph-continue-on-failure: false
|
|
gradle-version: ${{ inputs.gradle-version }}
|
|
build-root-directory: ${{ inputs.build-root-directory }}
|
|
cache-encryption-key: ${{ inputs.cache-encryption-key }}
|
|
build-scan-publish: ${{ inputs.build-scan-publish }}
|
|
build-scan-terms-of-service-url: ${{ inputs.build-scan-terms-of-service-url }}
|
|
build-scan-terms-of-service-agree: ${{ inputs.build-scan-terms-of-service-agree }}
|
|
artifact-retention-days: 1
|
|
arguments: |
|
|
--no-configure-on-demand
|
|
--dependency-verification=off
|
|
:ForceDependencyResolutionPlugin_resolveAllDependencies
|
|
${{ inputs.additional-arguments }}
|
|
- name: Download and submit dependency graph
|
|
if: ${{ inputs.dependency-graph == 'download-and-submit' }}
|
|
uses: gradle/actions/setup-gradle@v3.0.0
|
|
with:
|
|
dependency-graph: download-and-submit
|
|
dependency-graph-continue-on-failure: false
|
|
cache-disabled: true
|