mirror of
https://github.com/renovatebot/renovate.git
synced 2025-01-13 07:26:26 +00:00
feat: centralized cache directory (#10115)
Ignore environment variables and instead use static cache directory for third party tools. Closes #10094 BREAKING CHANGE: Renovate will now override any package manager cache locations configured in env variables. # Conflicts: # lib/manager/gomod/__snapshots__/artifacts.spec.ts.snap # lib/manager/gomod/artifacts.ts
This commit is contained in:
parent
365ed0573a
commit
0e91fda451
15 changed files with 36 additions and 117 deletions
|
@ -53,10 +53,7 @@ describe('bundler.updateArtifacts()', () => {
|
||||||
docker.resetPrefetchedImages();
|
docker.resetPrefetchedImages();
|
||||||
|
|
||||||
setAdminConfig(adminConfig);
|
setAdminConfig(adminConfig);
|
||||||
|
fs.ensureCacheDir.mockResolvedValue('/tmp/cache/others/gem');
|
||||||
fs.ensureCacheDir.mockResolvedValueOnce(
|
|
||||||
join(adminConfig.cacheDir, './others/gem')
|
|
||||||
);
|
|
||||||
});
|
});
|
||||||
afterEach(() => {
|
afterEach(() => {
|
||||||
setAdminConfig();
|
setAdminConfig();
|
||||||
|
|
|
@ -172,13 +172,11 @@ export async function updateArtifacts(
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
const cacheDir = await ensureCacheDir('./others/gem', 'GEM_HOME');
|
|
||||||
|
|
||||||
const execOptions: ExecOptions = {
|
const execOptions: ExecOptions = {
|
||||||
cwdFile: packageFileName,
|
cwdFile: packageFileName,
|
||||||
extraEnv: {
|
extraEnv: {
|
||||||
...bundlerHostRulesVariables,
|
...bundlerHostRulesVariables,
|
||||||
GEM_HOME: cacheDir,
|
GEM_HOME: await ensureCacheDir('bundler'),
|
||||||
},
|
},
|
||||||
docker: {
|
docker: {
|
||||||
image: 'ruby',
|
image: 'ruby',
|
||||||
|
|
|
@ -67,13 +67,11 @@ export async function updateArtifacts({
|
||||||
);
|
);
|
||||||
const tagConstraint = match?.groups?.cocoapodsVersion ?? null;
|
const tagConstraint = match?.groups?.cocoapodsVersion ?? null;
|
||||||
|
|
||||||
const cacheDir = await ensureCacheDir('./others/cocoapods', 'CP_HOME_DIR');
|
|
||||||
|
|
||||||
const cmd = [...getPluginCommands(newPackageFileContent), 'pod install'];
|
const cmd = [...getPluginCommands(newPackageFileContent), 'pod install'];
|
||||||
const execOptions: ExecOptions = {
|
const execOptions: ExecOptions = {
|
||||||
cwdFile: packageFileName,
|
cwdFile: packageFileName,
|
||||||
extraEnv: {
|
extraEnv: {
|
||||||
CP_HOME_DIR: cacheDir,
|
CP_HOME_DIR: await ensureCacheDir('cocoapods'),
|
||||||
},
|
},
|
||||||
docker: {
|
docker: {
|
||||||
image: 'cocoapods',
|
image: 'cocoapods',
|
||||||
|
|
|
@ -49,10 +49,7 @@ describe('.updateArtifacts()', () => {
|
||||||
docker.resetPrefetchedImages();
|
docker.resetPrefetchedImages();
|
||||||
hostRules.clear();
|
hostRules.clear();
|
||||||
setAdminConfig(adminConfig);
|
setAdminConfig(adminConfig);
|
||||||
fs.ensureCacheDir.mockResolvedValue(
|
fs.ensureCacheDir.mockResolvedValue('/tmp/renovate/cache/others/composer');
|
||||||
join(adminConfig.cacheDir, './others/composer')
|
|
||||||
);
|
|
||||||
|
|
||||||
datasource.getPkgReleases.mockResolvedValueOnce({
|
datasource.getPkgReleases.mockResolvedValueOnce({
|
||||||
releases: [
|
releases: [
|
||||||
{ version: '1.0.0' },
|
{ version: '1.0.0' },
|
||||||
|
|
|
@ -81,11 +81,6 @@ export async function updateArtifacts({
|
||||||
}: UpdateArtifact): Promise<UpdateArtifactsResult[] | null> {
|
}: UpdateArtifact): Promise<UpdateArtifactsResult[] | null> {
|
||||||
logger.debug(`composer.updateArtifacts(${packageFileName})`);
|
logger.debug(`composer.updateArtifacts(${packageFileName})`);
|
||||||
|
|
||||||
const cacheDir = await ensureCacheDir(
|
|
||||||
'./others/composer',
|
|
||||||
'COMPOSER_CACHE_DIR'
|
|
||||||
);
|
|
||||||
|
|
||||||
const lockFileName = packageFileName.replace(/\.json$/, '.lock');
|
const lockFileName = packageFileName.replace(/\.json$/, '.lock');
|
||||||
const existingLockFileContent = await readLocalFile(lockFileName, 'utf8');
|
const existingLockFileContent = await readLocalFile(lockFileName, 'utf8');
|
||||||
if (!existingLockFileContent) {
|
if (!existingLockFileContent) {
|
||||||
|
@ -118,7 +113,7 @@ export async function updateArtifacts({
|
||||||
const execOptions: ExecOptions = {
|
const execOptions: ExecOptions = {
|
||||||
cwdFile: packageFileName,
|
cwdFile: packageFileName,
|
||||||
extraEnv: {
|
extraEnv: {
|
||||||
COMPOSER_CACHE_DIR: cacheDir,
|
COMPOSER_CACHE_DIR: await ensureCacheDir('composer'),
|
||||||
COMPOSER_AUTH: getAuthJson(),
|
COMPOSER_AUTH: getAuthJson(),
|
||||||
},
|
},
|
||||||
docker: {
|
docker: {
|
||||||
|
|
|
@ -284,7 +284,7 @@ Array [
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
Object {
|
Object {
|
||||||
"cmd": "docker run --rm --name=renovate_go --label=renovate_child -v \\"/tmp/github/some/repo\\":\\"/tmp/github/some/repo\\" -v \\"/tmp/renovate/cache\\":\\"/tmp/renovate/cache\\" -v \\"/tmp/renovate/cache/others/go\\":\\"/tmp/renovate/cache/others/go\\" -e GOPATH -e GOPROXY -e GOPRIVATE -e GONOPROXY -e GONOSUMDB -e GOFLAGS -e CGO_ENABLED -w \\"/tmp/github/some/repo\\" renovate/go:latest bash -l -c \\"git config --global url.\\\\\\"https://some-token@github.com/\\\\\\".insteadOf \\\\\\"https://github.com/\\\\\\" && go get -d ./...\\"",
|
"cmd": "docker run --rm --name=renovate_go --label=renovate_child -v \\"/tmp/github/some/repo\\":\\"/tmp/github/some/repo\\" -v \\"/tmp/renovate/cache\\":\\"/tmp/renovate/cache\\" -e GOPATH -e GOPROXY -e GOPRIVATE -e GONOPROXY -e GONOSUMDB -e GOFLAGS -e CGO_ENABLED -w \\"/tmp/github/some/repo\\" renovate/go:latest bash -l -c \\"git config --global url.\\\\\\"https://some-token@github.com/\\\\\\".insteadOf \\\\\\"https://github.com/\\\\\\" && go get -d ./...\\"",
|
||||||
"options": Object {
|
"options": Object {
|
||||||
"cwd": "/tmp/github/some/repo",
|
"cwd": "/tmp/github/some/repo",
|
||||||
"encoding": "utf-8",
|
"encoding": "utf-8",
|
||||||
|
@ -326,7 +326,7 @@ Array [
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
Object {
|
Object {
|
||||||
"cmd": "docker run --rm --name=renovate_go --label=renovate_child -v \\"/tmp/github/some/repo\\":\\"/tmp/github/some/repo\\" -v \\"/tmp/renovate/cache\\":\\"/tmp/renovate/cache\\" -v \\"/tmp/renovate/cache/others/go\\":\\"/tmp/renovate/cache/others/go\\" -e GOPATH -e GOPROXY -e GOPRIVATE -e GONOPROXY -e GONOSUMDB -e GOFLAGS -e CGO_ENABLED -w \\"/tmp/github/some/repo\\" renovate/go:latest bash -l -c \\"go get -d ./... && go mod tidy && go mod tidy\\"",
|
"cmd": "docker run --rm --name=renovate_go --label=renovate_child -v \\"/tmp/github/some/repo\\":\\"/tmp/github/some/repo\\" -v \\"/tmp/renovate/cache\\":\\"/tmp/renovate/cache\\" -e GOPATH -e GOPROXY -e GOPRIVATE -e GONOPROXY -e GONOSUMDB -e GOFLAGS -e CGO_ENABLED -w \\"/tmp/github/some/repo\\" renovate/go:latest bash -l -c \\"go get -d ./... && go mod tidy && go mod tidy\\"",
|
||||||
"options": Object {
|
"options": Object {
|
||||||
"cwd": "/tmp/github/some/repo",
|
"cwd": "/tmp/github/some/repo",
|
||||||
"encoding": "utf-8",
|
"encoding": "utf-8",
|
||||||
|
@ -368,7 +368,7 @@ Array [
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
Object {
|
Object {
|
||||||
"cmd": "docker run --rm --name=renovate_go --label=renovate_child -v \\"/tmp/github/some/repo\\":\\"/tmp/github/some/repo\\" -v \\"/tmp/renovate/cache\\":\\"/tmp/renovate/cache\\" -v \\"/tmp/renovate/cache/others/go\\":\\"/tmp/renovate/cache/others/go\\" -e GOPATH -e GOPROXY -e GOPRIVATE -e GONOPROXY -e GONOSUMDB -e GOFLAGS -e CGO_ENABLED -w \\"/tmp/github/some/repo\\" renovate/go:latest bash -l -c \\"go get -d ./...\\"",
|
"cmd": "docker run --rm --name=renovate_go --label=renovate_child -v \\"/tmp/github/some/repo\\":\\"/tmp/github/some/repo\\" -v \\"/tmp/renovate/cache\\":\\"/tmp/renovate/cache\\" -e GOPATH -e GOPROXY -e GOPRIVATE -e GONOPROXY -e GONOSUMDB -e GOFLAGS -e CGO_ENABLED -w \\"/tmp/github/some/repo\\" renovate/go:latest bash -l -c \\"go get -d ./...\\"",
|
||||||
"options": Object {
|
"options": Object {
|
||||||
"cwd": "/tmp/github/some/repo",
|
"cwd": "/tmp/github/some/repo",
|
||||||
"encoding": "utf-8",
|
"encoding": "utf-8",
|
||||||
|
|
|
@ -94,8 +94,6 @@ export async function updateArtifacts({
|
||||||
}: UpdateArtifact): Promise<UpdateArtifactsResult[] | null> {
|
}: UpdateArtifact): Promise<UpdateArtifactsResult[] | null> {
|
||||||
logger.debug(`gomod.updateArtifacts(${goModFileName})`);
|
logger.debug(`gomod.updateArtifacts(${goModFileName})`);
|
||||||
|
|
||||||
const goPath = await ensureCacheDir('./others/go', 'GOPATH');
|
|
||||||
|
|
||||||
const sumFileName = goModFileName.replace(/\.mod$/, '.sum');
|
const sumFileName = goModFileName.replace(/\.mod$/, '.sum');
|
||||||
const existingGoSumContent = await readLocalFile(sumFileName);
|
const existingGoSumContent = await readLocalFile(sumFileName);
|
||||||
if (!existingGoSumContent) {
|
if (!existingGoSumContent) {
|
||||||
|
@ -121,7 +119,7 @@ export async function updateArtifacts({
|
||||||
const execOptions: ExecOptions = {
|
const execOptions: ExecOptions = {
|
||||||
cwdFile: goModFileName,
|
cwdFile: goModFileName,
|
||||||
extraEnv: {
|
extraEnv: {
|
||||||
GOPATH: goPath,
|
GOPATH: await ensureCacheDir('go'),
|
||||||
GOPROXY: process.env.GOPROXY,
|
GOPROXY: process.env.GOPROXY,
|
||||||
GOPRIVATE: process.env.GOPRIVATE,
|
GOPRIVATE: process.env.GOPRIVATE,
|
||||||
GONOPROXY: process.env.GONOPROXY,
|
GONOPROXY: process.env.GONOPROXY,
|
||||||
|
@ -133,7 +131,6 @@ export async function updateArtifacts({
|
||||||
image: 'go',
|
image: 'go',
|
||||||
tagConstraint: config.constraints?.go,
|
tagConstraint: config.constraints?.go,
|
||||||
tagScheme: 'npm',
|
tagScheme: 'npm',
|
||||||
volumes: [goPath],
|
|
||||||
preCommands: getPreCommands(),
|
preCommands: getPreCommands(),
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
|
@ -420,17 +420,16 @@ export async function getAdditionalFiles(
|
||||||
|
|
||||||
const { additionalNpmrcContent, additionalYarnRcYml } = processHostRules();
|
const { additionalNpmrcContent, additionalYarnRcYml } = processHostRules();
|
||||||
|
|
||||||
const env = {
|
const env = getChildProcessEnv([
|
||||||
...getChildProcessEnv(),
|
'NPM_CONFIG_CACHE',
|
||||||
NPM_CONFIG_CACHE: await ensureCacheDir('./others/npm', 'NPM_CONFIG_CACHE'),
|
'YARN_CACHE_FOLDER',
|
||||||
YARN_CACHE_FOLDER: await ensureCacheDir(
|
'npm_config_store',
|
||||||
'./others/yarn',
|
]);
|
||||||
'YARN_CACHE_FOLDER'
|
env.NPM_CONFIG_CACHE = await ensureCacheDir('npm');
|
||||||
),
|
env.YARN_CACHE_FOLDER = await ensureCacheDir('yarn');
|
||||||
YARN_GLOBAL_FOLDER: await ensureCacheDir('./others/berry'),
|
env.YARN_GLOBAL_FOLDER = await ensureCacheDir('berry');
|
||||||
npm_config_store: await ensureCacheDir('./others/pnpm', 'npm_config_store'),
|
env.npm_config_store = await ensureCacheDir('pnpm');
|
||||||
NODE_ENV: 'dev',
|
env.NODE_ENV = 'dev';
|
||||||
};
|
|
||||||
|
|
||||||
let token = '';
|
let token = '';
|
||||||
try {
|
try {
|
||||||
|
|
|
@ -46,7 +46,7 @@ describe('updateArtifacts', () => {
|
||||||
getDefaultRegistries.mockReturnValue([] as any);
|
getDefaultRegistries.mockReturnValue([] as any);
|
||||||
env.getChildProcessEnv.mockReturnValue(envMock.basic);
|
env.getChildProcessEnv.mockReturnValue(envMock.basic);
|
||||||
fs.ensureCacheDir.mockImplementation((dirName: string) =>
|
fs.ensureCacheDir.mockImplementation((dirName: string) =>
|
||||||
Promise.resolve(dirName)
|
Promise.resolve(`others/${dirName}`)
|
||||||
);
|
);
|
||||||
getRandomString.mockReturnValue('not-so-random' as any);
|
getRandomString.mockReturnValue('not-so-random' as any);
|
||||||
setAdminConfig(adminConfig);
|
setAdminConfig(adminConfig);
|
||||||
|
|
|
@ -64,10 +64,9 @@ async function runDotnetRestore(
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
const nugetConfigDir = await ensureCacheDir(
|
const nugetCacheDir = await ensureCacheDir('nuget');
|
||||||
`./others/nuget/${getRandomString()}`
|
const nugetConfigDir = join(nugetCacheDir, `${getRandomString()}`);
|
||||||
);
|
const nugetConfigFile = join(nugetConfigDir, `nuget.config`);
|
||||||
const nugetConfigFile = join(nugetConfigDir, 'nuget.config');
|
|
||||||
await outputFile(
|
await outputFile(
|
||||||
nugetConfigFile,
|
nugetConfigFile,
|
||||||
`<?xml version="1.0" encoding="utf-8"?>\n<configuration>\n</configuration>\n`
|
`<?xml version="1.0" encoding="utf-8"?>\n<configuration>\n</configuration>\n`
|
||||||
|
|
|
@ -15,8 +15,7 @@ export async function getExtractFile(): Promise<string> {
|
||||||
return extractPy;
|
return extractPy;
|
||||||
}
|
}
|
||||||
|
|
||||||
const cacheDir = await ensureCacheDir('./others/pip_setup');
|
extractPy = join(await ensureCacheDir('pip_setup'), EXTRACT);
|
||||||
extractPy = join(cacheDir, EXTRACT);
|
|
||||||
await outputFile(extractPy, dataFiles.get('data/extract.py'));
|
await outputFile(extractPy, dataFiles.get('data/extract.py'));
|
||||||
|
|
||||||
return extractPy;
|
return extractPy;
|
||||||
|
|
|
@ -122,7 +122,7 @@ Array [
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
Object {
|
Object {
|
||||||
"cmd": "docker run --rm --name=renovate_python --label=renovate_child -v \\"/tmp/github/some/repo\\":\\"/tmp/github/some/repo\\" -v \\"/tmp/renovate/cache\\":\\"/tmp/renovate/cache\\" -v \\"/tmp/renovate/cache/others/pipenv\\":\\"/tmp/renovate/cache/others/pipenv\\" -e PIPENV_CACHE_DIR -w \\"/tmp/github/some/repo\\" renovate/python:latest bash -l -c \\"pip install --user pipenv && pipenv lock\\"",
|
"cmd": "docker run --rm --name=renovate_python --label=renovate_child -v \\"/tmp/github/some/repo\\":\\"/tmp/github/some/repo\\" -v \\"/tmp/renovate/cache\\":\\"/tmp/renovate/cache\\" -e PIPENV_CACHE_DIR -w \\"/tmp/github/some/repo\\" renovate/python:latest bash -l -c \\"pip install --user pipenv && pipenv lock\\"",
|
||||||
"options": Object {
|
"options": Object {
|
||||||
"cwd": "/tmp/github/some/repo",
|
"cwd": "/tmp/github/some/repo",
|
||||||
"encoding": "utf-8",
|
"encoding": "utf-8",
|
||||||
|
@ -158,7 +158,7 @@ Array [
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
Object {
|
Object {
|
||||||
"cmd": "docker run --rm --name=renovate_python --label=renovate_child -v \\"/tmp/github/some/repo\\":\\"/tmp/github/some/repo\\" -v \\"/tmp/renovate/cache\\":\\"/tmp/renovate/cache\\" -v \\"/tmp/renovate/cache/others/pipenv\\":\\"/tmp/renovate/cache/others/pipenv\\" -e PIPENV_CACHE_DIR -w \\"/tmp/github/some/repo\\" renovate/python bash -l -c \\"pip install --user pipenv==2020.8.13 && pipenv lock\\"",
|
"cmd": "docker run --rm --name=renovate_python --label=renovate_child -v \\"/tmp/github/some/repo\\":\\"/tmp/github/some/repo\\" -v \\"/tmp/renovate/cache\\":\\"/tmp/renovate/cache\\" -e PIPENV_CACHE_DIR -w \\"/tmp/github/some/repo\\" renovate/python bash -l -c \\"pip install --user pipenv==2020.8.13 && pipenv lock\\"",
|
||||||
"options": Object {
|
"options": Object {
|
||||||
"cwd": "/tmp/github/some/repo",
|
"cwd": "/tmp/github/some/repo",
|
||||||
"encoding": "utf-8",
|
"encoding": "utf-8",
|
||||||
|
@ -194,7 +194,7 @@ Array [
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
Object {
|
Object {
|
||||||
"cmd": "docker run --rm --name=renovate_python --label=renovate_child -v \\"/tmp/github/some/repo\\":\\"/tmp/github/some/repo\\" -v \\"/tmp/renovate/cache\\":\\"/tmp/renovate/cache\\" -v \\"/tmp/renovate/cache/others/pipenv\\":\\"/tmp/renovate/cache/others/pipenv\\" -e PIPENV_CACHE_DIR -w \\"/tmp/github/some/repo\\" renovate/python bash -l -c \\"pip install --user pipenv==2020.8.13 && pipenv lock\\"",
|
"cmd": "docker run --rm --name=renovate_python --label=renovate_child -v \\"/tmp/github/some/repo\\":\\"/tmp/github/some/repo\\" -v \\"/tmp/renovate/cache\\":\\"/tmp/renovate/cache\\" -e PIPENV_CACHE_DIR -w \\"/tmp/github/some/repo\\" renovate/python bash -l -c \\"pip install --user pipenv==2020.8.13 && pipenv lock\\"",
|
||||||
"options": Object {
|
"options": Object {
|
||||||
"cwd": "/tmp/github/some/repo",
|
"cwd": "/tmp/github/some/repo",
|
||||||
"encoding": "utf-8",
|
"encoding": "utf-8",
|
||||||
|
@ -230,7 +230,7 @@ Array [
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
Object {
|
Object {
|
||||||
"cmd": "docker run --rm --name=renovate_python --label=renovate_child -v \\"/tmp/github/some/repo\\":\\"/tmp/github/some/repo\\" -v \\"/tmp/renovate/cache\\":\\"/tmp/renovate/cache\\" -v \\"/tmp/renovate/cache/others/pipenv\\":\\"/tmp/renovate/cache/others/pipenv\\" -e PIPENV_CACHE_DIR -w \\"/tmp/github/some/repo\\" renovate/python bash -l -c \\"pip install --user pipenv==2020.1.1 && pipenv lock\\"",
|
"cmd": "docker run --rm --name=renovate_python --label=renovate_child -v \\"/tmp/github/some/repo\\":\\"/tmp/github/some/repo\\" -v \\"/tmp/renovate/cache\\":\\"/tmp/renovate/cache\\" -e PIPENV_CACHE_DIR -w \\"/tmp/github/some/repo\\" renovate/python bash -l -c \\"pip install --user pipenv==2020.1.1 && pipenv lock\\"",
|
||||||
"options": Object {
|
"options": Object {
|
||||||
"cwd": "/tmp/github/some/repo",
|
"cwd": "/tmp/github/some/repo",
|
||||||
"encoding": "utf-8",
|
"encoding": "utf-8",
|
||||||
|
|
|
@ -77,8 +77,6 @@ export async function updateArtifacts({
|
||||||
}: UpdateArtifact): Promise<UpdateArtifactsResult[] | null> {
|
}: UpdateArtifact): Promise<UpdateArtifactsResult[] | null> {
|
||||||
logger.debug(`pipenv.updateArtifacts(${pipfileName})`);
|
logger.debug(`pipenv.updateArtifacts(${pipfileName})`);
|
||||||
|
|
||||||
const cacheDir = await ensureCacheDir('./others/pipenv', 'PIPENV_CACHE_DIR');
|
|
||||||
|
|
||||||
const lockFileName = pipfileName + '.lock';
|
const lockFileName = pipfileName + '.lock';
|
||||||
const existingLockFileContent = await readLocalFile(lockFileName, 'utf8');
|
const existingLockFileContent = await readLocalFile(lockFileName, 'utf8');
|
||||||
if (!existingLockFileContent) {
|
if (!existingLockFileContent) {
|
||||||
|
@ -99,7 +97,7 @@ export async function updateArtifacts({
|
||||||
const execOptions: ExecOptions = {
|
const execOptions: ExecOptions = {
|
||||||
cwdFile: pipfileName,
|
cwdFile: pipfileName,
|
||||||
extraEnv: {
|
extraEnv: {
|
||||||
PIPENV_CACHE_DIR: cacheDir,
|
PIPENV_CACHE_DIR: await ensureCacheDir('pipenv'),
|
||||||
},
|
},
|
||||||
docker: {
|
docker: {
|
||||||
image: 'python',
|
image: 'python',
|
||||||
|
@ -108,7 +106,6 @@ export async function updateArtifacts({
|
||||||
preCommands: [
|
preCommands: [
|
||||||
`pip install --user ${quote(`pipenv${pipenvConstraint}`)}`,
|
`pip install --user ${quote(`pipenv${pipenvConstraint}`)}`,
|
||||||
],
|
],
|
||||||
volumes: [cacheDir],
|
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
logger.debug({ cmd }, 'pipenv lock command');
|
logger.debug({ cmd }, 'pipenv lock command');
|
||||||
|
|
|
@ -166,13 +166,12 @@ describe(getName(), () => {
|
||||||
dirFromEnv: string;
|
dirFromEnv: string;
|
||||||
dirFromConfig: string;
|
dirFromConfig: string;
|
||||||
} {
|
} {
|
||||||
const dirFromEnv = join(root, join('/foo'));
|
const dirFromEnv = join(root, join('/bar/others/bundler'));
|
||||||
const dirFromConfig = join(root, join('/bar'));
|
const dirFromConfig = join(root, join('/bar'));
|
||||||
|
|
||||||
jest.resetAllMocks();
|
jest.resetAllMocks();
|
||||||
env.getChildProcessEnv.mockReturnValueOnce({
|
env.getChildProcessEnv.mockReturnValueOnce({
|
||||||
...envMock.basic,
|
...envMock.basic,
|
||||||
CUSTOM_CACHE_DIR: dirFromEnv,
|
|
||||||
});
|
});
|
||||||
|
|
||||||
setAdminConfig({
|
setAdminConfig({
|
||||||
|
@ -185,45 +184,10 @@ describe(getName(), () => {
|
||||||
it('prefers environment variables over admin config', async () => {
|
it('prefers environment variables over admin config', async () => {
|
||||||
await withDir(
|
await withDir(
|
||||||
async (tmpDir) => {
|
async (tmpDir) => {
|
||||||
const { dirFromEnv, dirFromConfig } = setupMock(tmpDir.path);
|
const { dirFromEnv } = setupMock(tmpDir.path);
|
||||||
const res = await ensureCacheDir(
|
const res = await ensureCacheDir('bundler');
|
||||||
'./deeply/nested',
|
|
||||||
'CUSTOM_CACHE_DIR'
|
|
||||||
);
|
|
||||||
expect(res).toEqual(dirFromEnv);
|
expect(res).toEqual(dirFromEnv);
|
||||||
expect(await exists(dirFromEnv)).toBeTrue();
|
expect(await exists(dirFromEnv)).toBeTrue();
|
||||||
expect(await exists(dirFromConfig)).toBeFalse();
|
|
||||||
},
|
|
||||||
{ unsafeCleanup: true }
|
|
||||||
);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('is optional to pass environment variable', async () => {
|
|
||||||
await withDir(
|
|
||||||
async (tmpDir) => {
|
|
||||||
const { dirFromEnv, dirFromConfig } = setupMock(tmpDir.path);
|
|
||||||
const expected = join(`${dirFromConfig}/deeply/nested`);
|
|
||||||
const res = await ensureCacheDir('./deeply/nested');
|
|
||||||
expect(res).toEqual(expected);
|
|
||||||
expect(await exists(expected)).toBeTrue();
|
|
||||||
expect(await exists(dirFromEnv)).toBeFalse();
|
|
||||||
},
|
|
||||||
{ unsafeCleanup: true }
|
|
||||||
);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('falls back to admin config', async () => {
|
|
||||||
await withDir(
|
|
||||||
async (tmpDir) => {
|
|
||||||
const { dirFromEnv, dirFromConfig } = setupMock(tmpDir.path);
|
|
||||||
const expected = join(`${dirFromConfig}/deeply/nested`);
|
|
||||||
const res = await ensureCacheDir(
|
|
||||||
'./deeply/nested',
|
|
||||||
'NO_SUCH_VARIABLE'
|
|
||||||
);
|
|
||||||
expect(res).toEqual(expected);
|
|
||||||
expect(await exists(expected)).toBeTrue();
|
|
||||||
expect(await exists(dirFromEnv)).toBeFalse();
|
|
||||||
},
|
},
|
||||||
{ unsafeCleanup: true }
|
{ unsafeCleanup: true }
|
||||||
);
|
);
|
||||||
|
|
|
@ -5,7 +5,6 @@ import * as fs from 'fs-extra';
|
||||||
import { isAbsolute, join, parse } from 'upath';
|
import { isAbsolute, join, parse } from 'upath';
|
||||||
import { getAdminConfig } from '../../config/admin';
|
import { getAdminConfig } from '../../config/admin';
|
||||||
import { logger } from '../../logger';
|
import { logger } from '../../logger';
|
||||||
import { getChildProcessEnv } from '../exec/env';
|
|
||||||
|
|
||||||
export * from './proxies';
|
export * from './proxies';
|
||||||
|
|
||||||
|
@ -83,30 +82,10 @@ export async function ensureLocalDir(dirName: string): Promise<void> {
|
||||||
await fs.ensureDir(localDirName);
|
await fs.ensureDir(localDirName);
|
||||||
}
|
}
|
||||||
|
|
||||||
export async function ensureCacheDir(
|
export async function ensureCacheDir(name: string): Promise<string> {
|
||||||
adminCacheSubdir: string,
|
const cacheDirName = join(getAdminConfig().cacheDir, `others/${name}`);
|
||||||
envCacheVar?: string
|
await fs.ensureDir(cacheDirName);
|
||||||
): Promise<string> {
|
return cacheDirName;
|
||||||
let cacheDir: string;
|
|
||||||
if (envCacheVar) {
|
|
||||||
const env = getChildProcessEnv([envCacheVar]);
|
|
||||||
if (env[envCacheVar]) {
|
|
||||||
cacheDir = env[envCacheVar];
|
|
||||||
logger.debug(
|
|
||||||
{ cacheDir },
|
|
||||||
`Using cache directory from environment: ${envCacheVar}`
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!cacheDir) {
|
|
||||||
const { cacheDir: adminCacheDir } = getAdminConfig();
|
|
||||||
cacheDir = join(adminCacheDir, adminCacheSubdir);
|
|
||||||
logger.debug({ cacheDir }, `Using cache directory from admin config`);
|
|
||||||
}
|
|
||||||
|
|
||||||
await fs.ensureDir(cacheDir);
|
|
||||||
return cacheDir;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
Loading…
Reference in a new issue