renovate/lib/manager/pipenv/artifacts.js
2019-02-09 07:08:15 +01:00

108 lines
3.3 KiB
JavaScript

const { exec } = require('child-process-promise');
const fs = require('fs-extra');
const os = require('os');
const upath = require('upath');
module.exports = {
getArtifacts,
};
async function getArtifacts(
pipfileName,
updatedDeps,
newPipfileContent,
config
) {
logger.debug(`pipenv.getArtifacts(${pipfileName})`);
process.env.PIPENV_CACHE_DIR =
process.env.PIPENV_CACHE_DIR ||
upath.join(os.tmpdir(), '/renovate/cache/pipenv');
await fs.ensureDir(process.env.PIPENV_CACHE_DIR);
logger.debug('Using pipenv cache ' + process.env.PIPENV_CACHE_DIR);
const lockFileName = pipfileName + '.lock';
const existingLockFileContent = await platform.getFile(lockFileName);
if (!existingLockFileContent) {
logger.debug('No Pipfile.lock found');
return null;
}
const cwd = upath.join(config.localDir, upath.dirname(pipfileName));
let stdout;
let stderr;
try {
const localPipfileFileName = upath.join(config.localDir, pipfileName);
await fs.outputFile(localPipfileFileName, newPipfileContent);
const localLockFileName = upath.join(config.localDir, lockFileName);
const env =
global.trustLevel === 'high'
? process.env
: {
HOME: process.env.HOME,
PATH: process.env.PATH,
LC_ALL: process.env.LC_ALL,
LANG: process.env.LANG,
PIPENV_CACHE_DIR: process.env.PIPENV_CACHE_DIR,
};
const startTime = process.hrtime();
let cmd;
if (config.binarySource === 'docker') {
logger.info('Running pipenv via docker');
cmd = `docker run --rm `;
const volumes = [config.localDir, process.env.PIPENV_CACHE_DIR];
cmd += volumes.map(v => `-v ${v}:${v} `).join('');
const envVars = ['LC_ALL', 'LANG', 'PIPENV_CACHE_DIR'];
cmd += envVars.map(e => `-e ${e} `).join('');
cmd += `-w ${cwd} `;
cmd += `renovate/pipenv pipenv`;
} else {
logger.info('Running pipenv via global command');
cmd = 'pipenv';
}
const args = 'lock';
logger.debug({ cmd, args }, 'pipenv lock command');
({ stdout, stderr } = await exec(`${cmd} ${args}`, {
cwd,
shell: true,
env,
}));
const duration = process.hrtime(startTime);
const seconds = Math.round(duration[0] + duration[1] / 1e9);
stdout = stdout ? stdout.replace(/(Locking|Running)[^\s]*?\s/g, '') : null;
logger.info(
{ seconds, type: 'Pipfile.lock', stdout, stderr },
'Generated lockfile'
);
// istanbul ignore if
if (config.gitFs) {
const status = await platform.getRepoStatus();
if (!status.modified.includes(lockFileName)) {
return null;
}
} else {
const newLockFileContent = await fs.readFile(localLockFileName, 'utf8');
if (newLockFileContent === existingLockFileContent) {
logger.debug('Pipfile.lock is unchanged');
return null;
}
}
logger.debug('Returning updated Pipfile.lock');
return [
{
file: {
name: lockFileName,
contents: await fs.readFile(localLockFileName, 'utf8'),
},
},
];
} catch (err) {
logger.warn({ err, message: err.message }, 'Failed to update Pipfile.lock');
return [
{
artifactError: {
lockFile: lockFileName,
stderr: err.message,
},
},
];
}
}