mirror of
https://github.com/gradle/gradle-build-action.git
synced 2025-04-06 13:24:13 +02:00
Cache downloaded Gradle distributions
This commit is contained in:
parent
24f744c493
commit
c511d263a6
2 changed files with 32 additions and 18 deletions
2
dist/main/index.js
vendored
2
dist/main/index.js
vendored
File diff suppressed because one or more lines are too long
|
@ -3,6 +3,7 @@ import * as os from 'os'
|
||||||
import * as path from 'path'
|
import * as path from 'path'
|
||||||
import * as httpm from '@actions/http-client'
|
import * as httpm from '@actions/http-client'
|
||||||
import * as core from '@actions/core'
|
import * as core from '@actions/core'
|
||||||
|
import * as cache from '@actions/cache'
|
||||||
import * as toolCache from '@actions/tool-cache'
|
import * as toolCache from '@actions/tool-cache'
|
||||||
|
|
||||||
import * as gradlew from './gradlew'
|
import * as gradlew from './gradlew'
|
||||||
|
@ -85,37 +86,50 @@ async function findGradleVersionDeclaration(
|
||||||
}
|
}
|
||||||
|
|
||||||
async function provisionGradle(version: string, url: string): Promise<string> {
|
async function provisionGradle(version: string, url: string): Promise<string> {
|
||||||
const cachedInstall: string = toolCache.find('gradle', version)
|
const tmpdir = path.join(os.homedir(), 'gradle-installations')
|
||||||
if (cachedInstall.length > 0) {
|
|
||||||
const cachedExecutable = executableFrom(cachedInstall)
|
|
||||||
core.info(`Provisioned Gradle executable ${cachedExecutable}`)
|
|
||||||
return cachedExecutable
|
|
||||||
}
|
|
||||||
|
|
||||||
const tmpdir = path.join(os.homedir(), 'gradle-provision-tmpdir')
|
|
||||||
|
|
||||||
core.info(`Downloading ${url}`)
|
|
||||||
|
|
||||||
const downloadPath = path.join(
|
const downloadPath = path.join(
|
||||||
tmpdir,
|
tmpdir,
|
||||||
`downloads/gradle-${version}-bin.zip`
|
`downloads/gradle-${version}-bin.zip`
|
||||||
)
|
)
|
||||||
|
|
||||||
|
const cacheKey = `gradle-${version}`
|
||||||
|
const restoreKey = await cache.restoreCache([downloadPath], cacheKey)
|
||||||
|
if (restoreKey) {
|
||||||
|
core.info(`Restored Gradle distribution ${cacheKey} from cache`)
|
||||||
|
} else {
|
||||||
|
core.info(
|
||||||
|
`Gradle distribution ${cacheKey} not found in cache. Will download and cache.`
|
||||||
|
)
|
||||||
await toolCache.downloadTool(url, downloadPath)
|
await toolCache.downloadTool(url, downloadPath)
|
||||||
core.info(
|
core.info(
|
||||||
`Downloaded at ${downloadPath}, size ${fs.statSync(downloadPath).size}`
|
`Downloaded ${url} to ${downloadPath} (size ${
|
||||||
|
fs.statSync(downloadPath).size
|
||||||
|
})`
|
||||||
)
|
)
|
||||||
|
|
||||||
|
try {
|
||||||
|
await cache.saveCache([downloadPath], cacheKey)
|
||||||
|
} catch (error) {
|
||||||
|
if (error.name === cache.ValidationError.name) {
|
||||||
|
throw error
|
||||||
|
} else if (error.name === cache.ReserveCacheError.name) {
|
||||||
|
core.info(error.message)
|
||||||
|
} else {
|
||||||
|
core.info(`[warning] ${error.message}`)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
const installsDir = path.join(tmpdir, 'installs')
|
const installsDir = path.join(tmpdir, 'installs')
|
||||||
await toolCache.extractZip(downloadPath, installsDir)
|
await toolCache.extractZip(downloadPath, installsDir)
|
||||||
const installDir = path.join(installsDir, `gradle-${version}`)
|
const installDir = path.join(installsDir, `gradle-${version}`)
|
||||||
core.info(`Extracted in ${installDir}`)
|
core.info(`Extracted Gradle ${version} to ${installDir}`)
|
||||||
|
|
||||||
const executable = executableFrom(installDir)
|
const executable = executableFrom(installDir)
|
||||||
fs.chmodSync(executable, '755')
|
fs.chmodSync(executable, '755')
|
||||||
core.info(`Provisioned Gradle executable ${executable}`)
|
core.info(`Provisioned Gradle executable ${executable}`)
|
||||||
|
|
||||||
toolCache.cacheDir(installDir, 'gradle', version)
|
|
||||||
|
|
||||||
return executable
|
return executable
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue