2019-07-25 06:17:19 +00:00
|
|
|
import { logger } from '../../logger';
|
2020-05-01 16:03:48 +00:00
|
|
|
import { ExecOptions, exec } from '../../util/exec';
|
2020-07-05 19:22:13 +00:00
|
|
|
import {
|
|
|
|
deleteLocalFile,
|
|
|
|
ensureCacheDir,
|
|
|
|
readLocalFile,
|
|
|
|
writeLocalFile,
|
|
|
|
} from '../../util/fs';
|
2020-07-04 11:52:33 +00:00
|
|
|
import { getRepoStatus } from '../../util/git';
|
2020-04-30 05:12:20 +00:00
|
|
|
import {
|
|
|
|
UpdateArtifact,
|
|
|
|
UpdateArtifactsConfig,
|
2020-05-01 16:03:48 +00:00
|
|
|
UpdateArtifactsResult,
|
2020-04-30 05:12:20 +00:00
|
|
|
} from '../common';
|
2018-11-23 06:58:25 +00:00
|
|
|
|
2020-04-30 05:12:20 +00:00
|
|
|
function getPythonConstraint(
|
|
|
|
existingLockFileContent: string,
|
|
|
|
config: UpdateArtifactsConfig
|
|
|
|
): string | undefined | null {
|
|
|
|
const { compatibility = {} } = config;
|
|
|
|
const { python } = compatibility;
|
|
|
|
|
|
|
|
if (python) {
|
|
|
|
logger.debug('Using python constraint from config');
|
|
|
|
return python;
|
|
|
|
}
|
|
|
|
try {
|
|
|
|
const pipfileLock = JSON.parse(existingLockFileContent);
|
|
|
|
if (pipfileLock?._meta?.requires?.python_version) {
|
|
|
|
return '== ' + pipfileLock._meta.requires.python_version + '.*';
|
|
|
|
}
|
|
|
|
if (pipfileLock?._meta?.requires?.python_full_version) {
|
|
|
|
return '== ' + pipfileLock._meta.requires.python_full_version;
|
|
|
|
}
|
|
|
|
} catch (err) {
|
|
|
|
// Do nothing
|
|
|
|
}
|
|
|
|
return undefined;
|
|
|
|
}
|
|
|
|
|
2020-01-17 11:18:34 +00:00
|
|
|
export async function updateArtifacts({
|
|
|
|
packageFileName: pipfileName,
|
|
|
|
newPackageFileContent: newPipfileContent,
|
|
|
|
config,
|
|
|
|
}: UpdateArtifact): Promise<UpdateArtifactsResult[] | null> {
|
2019-06-09 06:18:41 +00:00
|
|
|
logger.debug(`pipenv.updateArtifacts(${pipfileName})`);
|
2020-01-07 15:32:21 +00:00
|
|
|
|
2020-07-05 19:22:13 +00:00
|
|
|
const cacheDir = await ensureCacheDir('./others/pipenv', 'PIPENV_CACHE_DIR');
|
2020-02-09 12:26:48 +00:00
|
|
|
logger.debug('Using pipenv cache ' + cacheDir);
|
2020-01-07 15:32:21 +00:00
|
|
|
|
2018-11-23 06:58:25 +00:00
|
|
|
const lockFileName = pipfileName + '.lock';
|
2020-05-13 10:45:02 +00:00
|
|
|
const existingLockFileContent = await readLocalFile(lockFileName, 'utf8');
|
2018-11-23 06:58:25 +00:00
|
|
|
if (!existingLockFileContent) {
|
|
|
|
logger.debug('No Pipfile.lock found');
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
try {
|
2020-07-03 19:29:04 +00:00
|
|
|
await writeLocalFile(pipfileName, newPipfileContent);
|
2020-04-30 10:06:37 +00:00
|
|
|
if (config.isLockFileMaintenance) {
|
2020-07-03 19:29:04 +00:00
|
|
|
await deleteLocalFile(lockFileName);
|
2020-04-30 10:06:37 +00:00
|
|
|
}
|
2020-02-09 12:26:48 +00:00
|
|
|
const cmd = 'pipenv lock';
|
2020-04-30 05:12:20 +00:00
|
|
|
const tagConstraint = getPythonConstraint(existingLockFileContent, config);
|
2020-02-09 12:26:48 +00:00
|
|
|
const execOptions: ExecOptions = {
|
|
|
|
extraEnv: {
|
|
|
|
PIPENV_CACHE_DIR: cacheDir,
|
|
|
|
},
|
|
|
|
docker: {
|
2020-04-30 05:12:20 +00:00
|
|
|
image: 'renovate/python',
|
|
|
|
tagConstraint,
|
|
|
|
tagScheme: 'pep440',
|
|
|
|
preCommands: ['pip install --user pipenv'],
|
2020-02-09 12:26:48 +00:00
|
|
|
volumes: [cacheDir],
|
|
|
|
},
|
|
|
|
};
|
|
|
|
logger.debug({ cmd }, 'pipenv lock command');
|
|
|
|
await exec(cmd, execOptions);
|
2020-07-04 11:52:33 +00:00
|
|
|
const status = await getRepoStatus();
|
2019-05-25 04:23:44 +00:00
|
|
|
if (!(status && status.modified.includes(lockFileName))) {
|
|
|
|
return null;
|
2018-11-23 06:58:25 +00:00
|
|
|
}
|
|
|
|
logger.debug('Returning updated Pipfile.lock');
|
2019-02-08 13:50:06 +00:00
|
|
|
return [
|
|
|
|
{
|
|
|
|
file: {
|
|
|
|
name: lockFileName,
|
2020-07-03 19:29:04 +00:00
|
|
|
contents: await readLocalFile(lockFileName, 'utf8'),
|
2019-02-08 13:50:06 +00:00
|
|
|
},
|
2018-11-23 06:58:25 +00:00
|
|
|
},
|
2019-02-08 13:50:06 +00:00
|
|
|
];
|
2018-11-23 06:58:25 +00:00
|
|
|
} catch (err) {
|
2020-04-28 08:47:30 +00:00
|
|
|
logger.debug({ err }, 'Failed to update Pipfile.lock');
|
2019-02-08 13:50:06 +00:00
|
|
|
return [
|
|
|
|
{
|
|
|
|
artifactError: {
|
|
|
|
lockFile: lockFileName,
|
|
|
|
stderr: err.message,
|
|
|
|
},
|
2018-11-23 06:58:25 +00:00
|
|
|
},
|
2019-02-08 13:50:06 +00:00
|
|
|
];
|
2018-11-23 06:58:25 +00:00
|
|
|
}
|
|
|
|
}
|