setup-python/src/setup-python.ts

121 lines
3.7 KiB
TypeScript
Raw Normal View History

2019-08-20 21:27:52 +07:00
import * as core from '@actions/core';
import * as finder from './find-python';
import * as finderPyPy from './find-pypy';
2019-08-20 21:27:52 +07:00
import * as path from 'path';
import * as os from 'os';
import fs from 'fs';
import {getCacheDistributor} from './cache-distributions/cache-factory';
import {isCacheFeatureAvailable} from './utils';
2019-08-20 21:27:52 +07:00
function isPyPyVersion(versionSpec: string) {
return versionSpec.startsWith('pypy');
}
async function cacheDependencies(cache: string, pythonVersion: string) {
const cacheDependencyPath =
core.getInput('cache-dependency-path') || undefined;
const cacheDistributor = getCacheDistributor(
cache,
pythonVersion,
cacheDependencyPath
);
await cacheDistributor.restoreCache();
}
function resolveVersionInput(): string {
let version = core.getInput('python-version');
let versionFile = core.getInput('python-version-file');
if (version && versionFile) {
core.warning(
'Both python-version and python-version-file inputs are specified, only python-version will be used'
);
}
if (version) {
return version;
}
2022-06-30 18:38:43 +07:00
if (versionFile) {
const defaultVersionFile = '.python-version';
const VersionFileExists = fs.existsSync(versionFile);
const defaultVersionFileExists = fs.existsSync(defaultVersionFile);
if (!VersionFileExists && !defaultVersionFileExists) {
throw new Error(
`The specified python version file at: ${versionFile} does not exist and default ${defaultVersionFile} file isn't found`
);
}
if (VersionFileExists) {
version = fs.readFileSync(versionFile, 'utf8');
core.info(`Resolved ${versionFile} as ${version}`);
} else {
2022-06-30 18:44:10 +07:00
version = fs.readFileSync(defaultVersionFile, 'utf8');
core.info(`Resolved ${defaultVersionFile} as ${version}`);
2022-06-30 18:38:43 +07:00
}
return version;
}
2022-06-30 18:38:43 +07:00
core.warning(
"Neither 'python-version' nor 'python-version-file' inputs were supplied. "
);
return version;
}
2019-08-20 21:27:52 +07:00
async function run() {
if (process.env.AGENT_TOOLSDIRECTORY?.trim()) {
2022-02-18 02:21:13 +07:00
core.debug(
`Python is expected to be installed into AGENT_TOOLSDIRECTORY=${process.env['AGENT_TOOLSDIRECTORY']}`
2022-02-18 02:21:13 +07:00
);
process.env['RUNNER_TOOL_CACHE'] = process.env['AGENT_TOOLSDIRECTORY'];
} else {
2022-02-18 02:21:13 +07:00
core.debug(
`Python is expected to be installed into RUNNER_TOOL_CACHE==${process.env['RUNNER_TOOL_CACHE']}`
2022-02-18 02:21:13 +07:00
);
}
2019-08-20 21:27:52 +07:00
try {
const version = resolveVersionInput();
2019-08-20 21:27:52 +07:00
if (version) {
let pythonVersion: string;
const arch: string = core.getInput('architecture') || os.arch();
const updateEnvironment = core.getBooleanInput('update-environment');
if (isPyPyVersion(version)) {
const installed = await finderPyPy.findPyPyVersion(
version,
arch,
updateEnvironment
);
pythonVersion = `${installed.resolvedPyPyVersion}-${installed.resolvedPythonVersion}`;
core.info(
2022-05-03 19:43:53 +07:00
`Successfully set up PyPy ${installed.resolvedPyPyVersion} with Python (${installed.resolvedPythonVersion})`
);
} else {
const installed = await finder.useCpythonVersion(
version,
arch,
updateEnvironment
);
pythonVersion = installed.version;
2022-05-03 19:43:53 +07:00
core.info(`Successfully set up ${installed.impl} (${pythonVersion})`);
}
const cache = core.getInput('cache');
if (cache && isCacheFeatureAvailable()) {
await cacheDependencies(cache, pythonVersion);
}
} else {
core.warning(
2022-05-04 14:55:36 +07:00
'The `python-version` input is not set. The version of Python currently in `PATH` will be used.'
);
2019-08-20 21:27:52 +07:00
}
const matchersPath = path.join(__dirname, '../..', '.github');
core.info(`##[add-matcher]${path.join(matchersPath, 'python.json')}`);
2019-08-20 21:27:52 +07:00
} catch (err) {
core.setFailed((err as Error).message);
2019-08-20 21:27:52 +07:00
}
}
run();