mirror of
https://github.com/renovatebot/renovate.git
synced 2025-01-15 09:06:25 +00:00
dca3418bbd
Moves datasource, manager, platform and versioning code from lib/ into new lib/modules/ BREAKING CHANGE: External tools must update paths to datasource, manager, platform and versioning
141 lines
3.9 KiB
TypeScript
141 lines
3.9 KiB
TypeScript
import { quote } from 'shlex';
|
|
import { TEMPORARY_ERROR } from '../../../constants/error-messages';
|
|
import { logger } from '../../../logger';
|
|
import { exec } from '../../../util/exec';
|
|
import type { ExecOptions } from '../../../util/exec/types';
|
|
import {
|
|
deleteLocalFile,
|
|
ensureCacheDir,
|
|
readLocalFile,
|
|
writeLocalFile,
|
|
} from '../../../util/fs';
|
|
import { getRepoStatus } from '../../../util/git';
|
|
import type {
|
|
UpdateArtifact,
|
|
UpdateArtifactsConfig,
|
|
UpdateArtifactsResult,
|
|
} from '../types';
|
|
|
|
function getPythonConstraint(
|
|
existingLockFileContent: string,
|
|
config: UpdateArtifactsConfig
|
|
): string | undefined | null {
|
|
const { constraints = {} } = config;
|
|
const { python } = constraints;
|
|
|
|
if (python) {
|
|
logger.debug('Using python constraint from config');
|
|
return python;
|
|
}
|
|
try {
|
|
const pipfileLock = JSON.parse(existingLockFileContent);
|
|
if (pipfileLock?._meta?.requires?.python_version) {
|
|
const pythonVersion: string = pipfileLock._meta.requires.python_version;
|
|
return `== ${pythonVersion}.*`;
|
|
}
|
|
if (pipfileLock?._meta?.requires?.python_full_version) {
|
|
const pythonFullVersion: string =
|
|
pipfileLock._meta.requires.python_full_version;
|
|
return `== ${pythonFullVersion}`;
|
|
}
|
|
} catch (err) {
|
|
// Do nothing
|
|
}
|
|
return undefined;
|
|
}
|
|
|
|
function getPipenvConstraint(
|
|
existingLockFileContent: string,
|
|
config: UpdateArtifactsConfig
|
|
): string | null {
|
|
const { constraints = {} } = config;
|
|
const { pipenv } = constraints;
|
|
|
|
if (pipenv) {
|
|
logger.debug('Using pipenv constraint from config');
|
|
return pipenv;
|
|
}
|
|
try {
|
|
const pipfileLock = JSON.parse(existingLockFileContent);
|
|
if (pipfileLock?.default?.pipenv?.version) {
|
|
const pipenvVersion: string = pipfileLock.default.pipenv.version;
|
|
return pipenvVersion;
|
|
}
|
|
if (pipfileLock?.develop?.pipenv?.version) {
|
|
const pipenvVersion: string = pipfileLock.develop.pipenv.version;
|
|
return pipenvVersion;
|
|
}
|
|
} catch (err) {
|
|
// Do nothing
|
|
}
|
|
return '';
|
|
}
|
|
|
|
export async function updateArtifacts({
|
|
packageFileName: pipfileName,
|
|
newPackageFileContent: newPipfileContent,
|
|
config,
|
|
}: UpdateArtifact): Promise<UpdateArtifactsResult[] | null> {
|
|
logger.debug(`pipenv.updateArtifacts(${pipfileName})`);
|
|
|
|
const lockFileName = pipfileName + '.lock';
|
|
const existingLockFileContent = await readLocalFile(lockFileName, 'utf8');
|
|
if (!existingLockFileContent) {
|
|
logger.debug('No Pipfile.lock found');
|
|
return null;
|
|
}
|
|
try {
|
|
await writeLocalFile(pipfileName, newPipfileContent);
|
|
if (config.isLockFileMaintenance) {
|
|
await deleteLocalFile(lockFileName);
|
|
}
|
|
const cmd = 'pipenv lock';
|
|
const tagConstraint = getPythonConstraint(existingLockFileContent, config);
|
|
const pipenvConstraint = getPipenvConstraint(
|
|
existingLockFileContent,
|
|
config
|
|
);
|
|
const execOptions: ExecOptions = {
|
|
cwdFile: pipfileName,
|
|
extraEnv: {
|
|
PIPENV_CACHE_DIR: await ensureCacheDir('pipenv'),
|
|
},
|
|
docker: {
|
|
image: 'python',
|
|
tagConstraint,
|
|
tagScheme: 'pep440',
|
|
},
|
|
preCommands: [`pip install --user ${quote(`pipenv${pipenvConstraint}`)}`],
|
|
};
|
|
logger.debug({ cmd }, 'pipenv lock command');
|
|
await exec(cmd, execOptions);
|
|
const status = await getRepoStatus();
|
|
if (!status?.modified.includes(lockFileName)) {
|
|
return null;
|
|
}
|
|
logger.debug('Returning updated Pipfile.lock');
|
|
return [
|
|
{
|
|
file: {
|
|
type: 'addition',
|
|
path: lockFileName,
|
|
contents: await readLocalFile(lockFileName, 'utf8'),
|
|
},
|
|
},
|
|
];
|
|
} catch (err) {
|
|
// istanbul ignore if
|
|
if (err.message === TEMPORARY_ERROR) {
|
|
throw err;
|
|
}
|
|
logger.debug({ err }, 'Failed to update Pipfile.lock');
|
|
return [
|
|
{
|
|
artifactError: {
|
|
lockFile: lockFileName,
|
|
stderr: err.message,
|
|
},
|
|
},
|
|
];
|
|
}
|
|
}
|