mirror of https://github.com/actions/toolkit
reverting updated ghes logic for cache
parent
79886daf63
commit
fe8c762d61
|
@ -48,17 +48,7 @@ test('isGhes returns false for github.com', async () => {
|
||||||
expect(cacheUtils.isGhes()).toBe(false)
|
expect(cacheUtils.isGhes()).toBe(false)
|
||||||
})
|
})
|
||||||
|
|
||||||
test('isGhes returns false for ghe.com', async () => {
|
|
||||||
process.env.GITHUB_SERVER_URL = 'https://github.ghe.com'
|
|
||||||
expect(cacheUtils.isGhes()).toBe(false)
|
|
||||||
})
|
|
||||||
|
|
||||||
test('isGhes returns true for enterprise URL', async () => {
|
test('isGhes returns true for enterprise URL', async () => {
|
||||||
process.env.GITHUB_SERVER_URL = 'https://my-enterprise.github.com'
|
process.env.GITHUB_SERVER_URL = 'https://my-enterprise.github.com'
|
||||||
expect(cacheUtils.isGhes()).toBe(true)
|
expect(cacheUtils.isGhes()).toBe(true)
|
||||||
})
|
})
|
||||||
|
|
||||||
test('isGhes returns false for ghe.localhost', () => {
|
|
||||||
process.env.GITHUB_SERVER_URL = 'https://github.ghe.localhost'
|
|
||||||
expect(cacheUtils.isGhes()).toBe(false)
|
|
||||||
})
|
|
|
@ -7,11 +7,7 @@ import * as path from 'path'
|
||||||
import * as semver from 'semver'
|
import * as semver from 'semver'
|
||||||
import * as util from 'util'
|
import * as util from 'util'
|
||||||
import {v4 as uuidV4} from 'uuid'
|
import {v4 as uuidV4} from 'uuid'
|
||||||
import {
|
import {CacheFilename, CompressionMethod} from './constants'
|
||||||
CacheFilename,
|
|
||||||
CompressionMethod,
|
|
||||||
GnuTarPathOnWindows
|
|
||||||
} from './constants'
|
|
||||||
|
|
||||||
// From https://github.com/actions/toolkit/blob/main/packages/tool-cache/src/tool-cache.ts#L23
|
// From https://github.com/actions/toolkit/blob/main/packages/tool-cache/src/tool-cache.ts#L23
|
||||||
export async function createTempDirectory(): Promise<string> {
|
export async function createTempDirectory(): Promise<string> {
|
||||||
|
@ -56,12 +52,7 @@ export async function resolvePaths(patterns: string[]): Promise<string[]> {
|
||||||
.replace(new RegExp(`\\${path.sep}`, 'g'), '/')
|
.replace(new RegExp(`\\${path.sep}`, 'g'), '/')
|
||||||
core.debug(`Matched: ${relativeFile}`)
|
core.debug(`Matched: ${relativeFile}`)
|
||||||
// Paths are made relative so the tar entries are all relative to the root of the workspace.
|
// Paths are made relative so the tar entries are all relative to the root of the workspace.
|
||||||
if (relativeFile === '') {
|
paths.push(`${relativeFile}`)
|
||||||
// path.relative returns empty string if workspace and file are equal
|
|
||||||
paths.push('.')
|
|
||||||
} else {
|
|
||||||
paths.push(`${relativeFile}`)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return paths
|
return paths
|
||||||
|
@ -71,15 +62,11 @@ export async function unlinkFile(filePath: fs.PathLike): Promise<void> {
|
||||||
return util.promisify(fs.unlink)(filePath)
|
return util.promisify(fs.unlink)(filePath)
|
||||||
}
|
}
|
||||||
|
|
||||||
async function getVersion(
|
async function getVersion(app: string): Promise<string> {
|
||||||
app: string,
|
core.debug(`Checking ${app} --version`)
|
||||||
additionalArgs: string[] = []
|
|
||||||
): Promise<string> {
|
|
||||||
let versionOutput = ''
|
let versionOutput = ''
|
||||||
additionalArgs.push('--version')
|
|
||||||
core.debug(`Checking ${app} ${additionalArgs.join(' ')}`)
|
|
||||||
try {
|
try {
|
||||||
await exec.exec(`${app}`, additionalArgs, {
|
await exec.exec(`${app} --version`, [], {
|
||||||
ignoreReturnCode: true,
|
ignoreReturnCode: true,
|
||||||
silent: true,
|
silent: true,
|
||||||
listeners: {
|
listeners: {
|
||||||
|
@ -98,14 +85,23 @@ async function getVersion(
|
||||||
|
|
||||||
// Use zstandard if possible to maximize cache performance
|
// Use zstandard if possible to maximize cache performance
|
||||||
export async function getCompressionMethod(): Promise<CompressionMethod> {
|
export async function getCompressionMethod(): Promise<CompressionMethod> {
|
||||||
const versionOutput = await getVersion('zstd', ['--quiet'])
|
if (process.platform === 'win32' && !(await isGnuTarInstalled())) {
|
||||||
const version = semver.clean(versionOutput)
|
// Disable zstd due to bug https://github.com/actions/cache/issues/301
|
||||||
core.debug(`zstd version: ${version}`)
|
|
||||||
|
|
||||||
if (versionOutput === '') {
|
|
||||||
return CompressionMethod.Gzip
|
return CompressionMethod.Gzip
|
||||||
} else {
|
}
|
||||||
|
|
||||||
|
const versionOutput = await getVersion('zstd')
|
||||||
|
const version = semver.clean(versionOutput)
|
||||||
|
|
||||||
|
if (!versionOutput.toLowerCase().includes('zstd command line interface')) {
|
||||||
|
// zstd is not installed
|
||||||
|
return CompressionMethod.Gzip
|
||||||
|
} else if (!version || semver.lt(version, 'v1.3.2')) {
|
||||||
|
// zstd is installed but using a version earlier than v1.3.2
|
||||||
|
// v1.3.2 is required to use the `--long` options in zstd
|
||||||
return CompressionMethod.ZstdWithoutLong
|
return CompressionMethod.ZstdWithoutLong
|
||||||
|
} else {
|
||||||
|
return CompressionMethod.Zstd
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -115,12 +111,9 @@ export function getCacheFileName(compressionMethod: CompressionMethod): string {
|
||||||
: CacheFilename.Zstd
|
: CacheFilename.Zstd
|
||||||
}
|
}
|
||||||
|
|
||||||
export async function getGnuTarPathOnWindows(): Promise<string> {
|
export async function isGnuTarInstalled(): Promise<boolean> {
|
||||||
if (fs.existsSync(GnuTarPathOnWindows)) {
|
|
||||||
return GnuTarPathOnWindows
|
|
||||||
}
|
|
||||||
const versionOutput = await getVersion('tar')
|
const versionOutput = await getVersion('tar')
|
||||||
return versionOutput.toLowerCase().includes('gnu tar') ? io.which('tar') : ''
|
return versionOutput.toLowerCase().includes('gnu tar')
|
||||||
}
|
}
|
||||||
|
|
||||||
export function assertDefined<T>(name: string, value?: T): T {
|
export function assertDefined<T>(name: string, value?: T): T {
|
||||||
|
@ -135,14 +128,5 @@ export function isGhes(): boolean {
|
||||||
const ghUrl = new URL(
|
const ghUrl = new URL(
|
||||||
process.env['GITHUB_SERVER_URL'] || 'https://github.com'
|
process.env['GITHUB_SERVER_URL'] || 'https://github.com'
|
||||||
)
|
)
|
||||||
|
return ghUrl.hostname.toUpperCase() !== 'GITHUB.COM'
|
||||||
let githubHosts = [
|
|
||||||
'GITHUB.COM',
|
|
||||||
'GITHUB.GHE.COM',
|
|
||||||
'GITHUB.GHE.LOCALHOST'
|
|
||||||
];
|
|
||||||
|
|
||||||
const hostname = ghUrl.hostname.trimEnd().toUpperCase()
|
|
||||||
|
|
||||||
return !githubHosts.includes(hostname)
|
|
||||||
}
|
}
|
Loading…
Reference in New Issue