mirror of
https://github.com/gradle/gradle-build-action.git
synced 2025-04-05 21:04:15 +02:00
Allow entries with same Job ID to match in different workflows
Fixes #1017
This commit is contained in:
parent
270f30ba56
commit
0f286652df
3 changed files with 9 additions and 34 deletions
|
@ -259,9 +259,9 @@ This allows the most recent state to always be available in the GitHub actions c
|
||||||
### Finding a matching cache entry
|
### Finding a matching cache entry
|
||||||
|
|
||||||
In most cases, no exact match will exist for the cache key. Instead, the Gradle User Home will be restored for the closest matching cache entry, using a set of "restore keys". The entries will be matched with the following precedence:
|
In most cases, no exact match will exist for the cache key. Instead, the Gradle User Home will be restored for the closest matching cache entry, using a set of "restore keys". The entries will be matched with the following precedence:
|
||||||
- An exact match on OS, workflow, job, matrix and Git SHA
|
- An exact match on OS, workflow name, job id, matrix and Git SHA
|
||||||
- The most recent entry saved for the same OS, workflow, job and matrix values
|
- The most recent entry saved for the same OS, workflow name, job id and matrix values
|
||||||
- The most recent entry saved for the same OS, workflow and job
|
- The most recent entry saved for the same OS and job id
|
||||||
- The most recent entry saved for the same OS
|
- The most recent entry saved for the same OS
|
||||||
|
|
||||||
Due to branch scoping of cache entries, the above match will be first performed for entries from the same branch, and then for the default ('main') branch.
|
Due to branch scoping of cache entries, the above match will be first performed for entries from the same branch, and then for the default ('main') branch.
|
||||||
|
|
|
@ -86,10 +86,10 @@ export function generateCacheKey(cacheName: string): CacheKey {
|
||||||
// At the most general level, share caches for all executions on the same OS
|
// At the most general level, share caches for all executions on the same OS
|
||||||
const cacheKeyForEnvironment = `${cacheKeyBase}|${getCacheKeyEnvironment()}`
|
const cacheKeyForEnvironment = `${cacheKeyBase}|${getCacheKeyEnvironment()}`
|
||||||
|
|
||||||
// Prefer caches that run this job
|
// Then prefer caches that run job with the same ID
|
||||||
const cacheKeyForJob = `${cacheKeyForEnvironment}|${getCacheKeyJob()}`
|
const cacheKeyForJob = `${cacheKeyForEnvironment}|${getCacheKeyJob()}`
|
||||||
|
|
||||||
// Prefer (even more) jobs that run this job with the same context (matrix)
|
// Prefer (even more) jobs that run this job in the same workflow with the same context (matrix)
|
||||||
const cacheKeyForJobContext = `${cacheKeyForJob}[${getCacheKeyJobInstance()}]`
|
const cacheKeyForJobContext = `${cacheKeyForJob}[${getCacheKeyJobInstance()}]`
|
||||||
|
|
||||||
// Exact match on Git SHA
|
// Exact match on Git SHA
|
||||||
|
@ -113,12 +113,7 @@ function getCacheKeyEnvironment(): string {
|
||||||
}
|
}
|
||||||
|
|
||||||
function getCacheKeyJob(): string {
|
function getCacheKeyJob(): string {
|
||||||
return process.env[CACHE_KEY_JOB_VAR] || getCacheKeyForJob(github.context.workflow, github.context.job)
|
return process.env[CACHE_KEY_JOB_VAR] || github.context.job
|
||||||
}
|
|
||||||
|
|
||||||
export function getCacheKeyForJob(workflowName: string, jobId: string): string {
|
|
||||||
const sanitizedWorkflow = workflowName.replace(/,/g, '').toLowerCase()
|
|
||||||
return `${sanitizedWorkflow}-${jobId}`
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function getCacheKeyJobInstance(): string {
|
function getCacheKeyJobInstance(): string {
|
||||||
|
@ -127,25 +122,11 @@ function getCacheKeyJobInstance(): string {
|
||||||
return override
|
return override
|
||||||
}
|
}
|
||||||
|
|
||||||
// By default, we hash the full `matrix` data for the run, to uniquely identify this job invocation
|
// By default, we hash the workflow name and the full `matrix` data for the run, to uniquely identify this job invocation
|
||||||
// The only way we can obtain the `matrix` data is via the `workflow-job-context` parameter in action.yml.
|
// The only way we can obtain the `matrix` data is via the `workflow-job-context` parameter in action.yml.
|
||||||
|
const workflowName = github.context.workflow
|
||||||
const workflowJobContext = params.getJobMatrix()
|
const workflowJobContext = params.getJobMatrix()
|
||||||
return hashStrings([workflowJobContext])
|
return hashStrings([workflowName, workflowJobContext])
|
||||||
}
|
|
||||||
|
|
||||||
export function getUniqueLabelForJobInstance(): string {
|
|
||||||
return getUniqueLabelForJobInstanceValues(github.context.workflow, github.context.job, params.getJobMatrix())
|
|
||||||
}
|
|
||||||
|
|
||||||
export function getUniqueLabelForJobInstanceValues(workflow: string, jobId: string, matrixJson: string): string {
|
|
||||||
const matrix = JSON.parse(matrixJson)
|
|
||||||
const matrixString = Object.values(matrix).join('-')
|
|
||||||
const label = matrixString ? `${workflow}-${jobId}-${matrixString}` : `${workflow}-${jobId}`
|
|
||||||
return sanitize(label)
|
|
||||||
}
|
|
||||||
|
|
||||||
function sanitize(value: string): string {
|
|
||||||
return value.replace(/[^a-zA-Z0-9_-]/g, '').toLowerCase()
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function getCacheKeyJobExecution(): string {
|
function getCacheKeyJobExecution(): string {
|
||||||
|
|
|
@ -17,10 +17,4 @@ describe('cacheUtils-utils', () => {
|
||||||
expect(posixHash).toBe(windowsHash)
|
expect(posixHash).toBe(windowsHash)
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
describe('sanitizes workflow name in cache key', () => {
|
|
||||||
it('with comma', () => {
|
|
||||||
const cacheKey = cacheUtils.getCacheKeyForJob("Workflow, with,commas", "JOB_ID")
|
|
||||||
expect(cacheKey).toBe('workflow withcommas-JOB_ID')
|
|
||||||
})
|
|
||||||
})
|
|
||||||
})
|
})
|
||||||
|
|
Loading…
Add table
Reference in a new issue