mirror of
https://github.com/gradle/actions
synced 2025-01-18 21:32:31 +00:00
88 lines
3 KiB
TypeScript
88 lines
3 KiB
TypeScript
import * as core from '@actions/core'
|
|
import {isCacheCleanupEnabled, isCacheDisabled, isCacheReadOnly, isCacheWriteOnly} from './cache-utils'
|
|
import {CacheListener} from './cache-reporting'
|
|
import {DaemonController} from './daemon-controller'
|
|
import {GradleStateCache} from './cache-base'
|
|
import {CacheCleaner} from './cache-cleaner'
|
|
|
|
const CACHE_RESTORED_VAR = 'GRADLE_BUILD_ACTION_CACHE_RESTORED'
|
|
|
|
export async function restore(gradleUserHome: string, cacheListener: CacheListener): Promise<void> {
|
|
// Bypass restore cache on all but first action step in workflow.
|
|
if (process.env[CACHE_RESTORED_VAR]) {
|
|
core.info('Cache only restored on first action step.')
|
|
return
|
|
}
|
|
core.exportVariable(CACHE_RESTORED_VAR, true)
|
|
|
|
const gradleStateCache = new GradleStateCache(gradleUserHome)
|
|
|
|
if (isCacheDisabled()) {
|
|
core.info('Cache is disabled: will not restore state from previous builds.')
|
|
// Initialize the Gradle User Home even when caching is disabled.
|
|
gradleStateCache.init()
|
|
cacheListener.cacheDisabled = true
|
|
return
|
|
}
|
|
|
|
if (gradleStateCache.cacheOutputExists()) {
|
|
core.info('Gradle User Home already exists: will not restore from cache.')
|
|
// Initialize pre-existing Gradle User Home.
|
|
gradleStateCache.init()
|
|
return
|
|
}
|
|
|
|
gradleStateCache.init()
|
|
// Mark the state as restored so that post-action will perform save.
|
|
core.saveState(CACHE_RESTORED_VAR, true)
|
|
|
|
if (isCacheWriteOnly()) {
|
|
core.info('Cache is write-only: will not restore from cache.')
|
|
cacheListener.cacheWriteOnly = true
|
|
return
|
|
}
|
|
|
|
await core.group('Restore Gradle state from cache', async () => {
|
|
await gradleStateCache.restore(cacheListener)
|
|
})
|
|
|
|
if (isCacheCleanupEnabled() && !isCacheReadOnly()) {
|
|
core.info('Preparing cache for cleanup.')
|
|
const cacheCleaner = new CacheCleaner(gradleUserHome, process.env['RUNNER_TEMP']!)
|
|
await cacheCleaner.prepare()
|
|
}
|
|
}
|
|
|
|
export async function save(
|
|
gradleUserHome: string,
|
|
cacheListener: CacheListener,
|
|
daemonController: DaemonController
|
|
): Promise<void> {
|
|
if (isCacheDisabled()) {
|
|
core.info('Cache is disabled: will not save state for later builds.')
|
|
return
|
|
}
|
|
|
|
if (!core.getState(CACHE_RESTORED_VAR)) {
|
|
core.info('Cache will not be saved: not restored in main action step.')
|
|
return
|
|
}
|
|
|
|
if (isCacheReadOnly()) {
|
|
core.info('Cache is read-only: will not save state for use in subsequent builds.')
|
|
cacheListener.cacheReadOnly = true
|
|
return
|
|
}
|
|
|
|
await daemonController.stopAllDaemons()
|
|
|
|
if (isCacheCleanupEnabled()) {
|
|
core.info('Forcing cache cleanup.')
|
|
const cacheCleaner = new CacheCleaner(gradleUserHome, process.env['RUNNER_TEMP']!)
|
|
await cacheCleaner.forceCleanup()
|
|
}
|
|
|
|
await core.group('Caching Gradle state', async () => {
|
|
return new GradleStateCache(gradleUserHome).save(cacheListener)
|
|
})
|
|
}
|