mirror of
https://github.com/gradle/gradle-build-action.git
synced 2025-04-05 21:04:15 +02:00
Allow artifact retention to be configured
- Default to retaining uploaded artifacts for 7 days. - Add a parameter to allow this to be configured.
This commit is contained in:
parent
f757bcfd86
commit
f381b1f027
4 changed files with 47 additions and 2 deletions
|
@ -68,6 +68,11 @@ inputs:
|
||||||
required: false
|
required: false
|
||||||
default: 'disabled'
|
default: 'disabled'
|
||||||
|
|
||||||
|
artifact-retention-days:
|
||||||
|
description: Specifies the number of days to retain any artifacts generated by the action. Defaults to 7 days. Set to zero for maximum retention.
|
||||||
|
required: false
|
||||||
|
default: 7
|
||||||
|
|
||||||
# EXPERIMENTAL & INTERNAL ACTION INPUTS
|
# EXPERIMENTAL & INTERNAL ACTION INPUTS
|
||||||
# The following action properties allow fine-grained tweaking of the action caching behaviour.
|
# The following action properties allow fine-grained tweaking of the action caching behaviour.
|
||||||
# These properties are experimental and not (yet) designed for production use, and may change without notice in a subsequent release of `gradle-build-action`.
|
# These properties are experimental and not (yet) designed for production use, and may change without notice in a subsequent release of `gradle-build-action`.
|
||||||
|
|
|
@ -11,7 +11,7 @@ import * as path from 'path'
|
||||||
import fs from 'fs'
|
import fs from 'fs'
|
||||||
|
|
||||||
import * as layout from './repository-layout'
|
import * as layout from './repository-layout'
|
||||||
import {DependencyGraphOption, getJobMatrix} from './input-params'
|
import {DependencyGraphOption, getJobMatrix, getArtifactRetentionDays} from './input-params'
|
||||||
|
|
||||||
const DEPENDENCY_GRAPH_ARTIFACT = 'dependency-graph'
|
const DEPENDENCY_GRAPH_ARTIFACT = 'dependency-graph'
|
||||||
|
|
||||||
|
@ -60,7 +60,9 @@ async function uploadDependencyGraphs(): Promise<string[]> {
|
||||||
core.info(`Uploading dependency graph files: ${relativeGraphFiles}`)
|
core.info(`Uploading dependency graph files: ${relativeGraphFiles}`)
|
||||||
|
|
||||||
const artifactClient = artifact.create()
|
const artifactClient = artifact.create()
|
||||||
artifactClient.uploadArtifact(DEPENDENCY_GRAPH_ARTIFACT, graphFiles, workspaceDirectory)
|
artifactClient.uploadArtifact(DEPENDENCY_GRAPH_ARTIFACT, graphFiles, workspaceDirectory, {
|
||||||
|
retentionDays: getArtifactRetentionDays()
|
||||||
|
})
|
||||||
|
|
||||||
return graphFiles
|
return graphFiles
|
||||||
}
|
}
|
||||||
|
|
|
@ -88,6 +88,22 @@ export function getDependencyGraphOption(): DependencyGraphOption {
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export function getArtifactRetentionDays(): number {
|
||||||
|
const val = core.getInput('artifact-retention-days')
|
||||||
|
return parseNumericInput('artifact-retention-days', val, 7)
|
||||||
|
}
|
||||||
|
|
||||||
|
export function parseNumericInput(paramName: string, paramValue: string, paramDefault: number): number {
|
||||||
|
if (paramValue.length === 0) {
|
||||||
|
return paramDefault
|
||||||
|
}
|
||||||
|
const numericValue = parseInt(paramValue)
|
||||||
|
if (isNaN(numericValue)) {
|
||||||
|
throw TypeError(`The value '${paramValue}' is not a valid numeric value for '${paramName}'.`)
|
||||||
|
}
|
||||||
|
return numericValue
|
||||||
|
}
|
||||||
|
|
||||||
function getBooleanInput(paramName: string, paramDefault = false): boolean {
|
function getBooleanInput(paramName: string, paramDefault = false): boolean {
|
||||||
const paramValue = core.getInput(paramName)
|
const paramValue = core.getInput(paramName)
|
||||||
switch (paramValue.toLowerCase().trim()) {
|
switch (paramValue.toLowerCase().trim()) {
|
||||||
|
|
22
test/jest/input-params.test.ts
Normal file
22
test/jest/input-params.test.ts
Normal file
|
@ -0,0 +1,22 @@
|
||||||
|
import * as inputParams from '../../src/input-params'
|
||||||
|
|
||||||
|
describe('input params', () => {
|
||||||
|
describe('parses numeric input', () => {
|
||||||
|
it('uses default value', () => {
|
||||||
|
const val = inputParams.parseNumericInput('param-name', '', 88)
|
||||||
|
expect(val).toBe(88)
|
||||||
|
})
|
||||||
|
it('parses numeric input', () => {
|
||||||
|
const val = inputParams.parseNumericInput('param-name', '34', 88)
|
||||||
|
expect(val).toBe(34)
|
||||||
|
})
|
||||||
|
it('fails on non-numeric input', () => {
|
||||||
|
const t = () => {
|
||||||
|
inputParams.parseNumericInput('param-name', 'xyz', 88)
|
||||||
|
};
|
||||||
|
|
||||||
|
expect(t).toThrow(TypeError)
|
||||||
|
expect(t).toThrow("The value 'xyz' is not a valid numeric value for 'param-name'.")
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
Loading…
Add table
Reference in a new issue