fix: ensure running setup-python in github actions

This commit is contained in:
Amin Yahyaabadi 2022-02-04 16:02:04 -08:00
parent 488c981727
commit ff997f2c40
4 changed files with 21 additions and 23 deletions

2
dist/setup_cpp.js vendored

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

View File

@ -6,7 +6,7 @@ import { setupChocoPack } from "../utils/setup/setupChocoPack"
import { isGitHubCI } from "../utils/env/isci"
export function setupPython(version: string, setupDir: string, arch: string) {
if (!isGitHubCI() || process.platform === "win32") {
if (!isGitHubCI()) {
// TODO parse version
return setupPythonViaSystem(version, setupDir, arch)
}
@ -23,7 +23,12 @@ export function setupPython(version: string, setupDir: string, arch: string) {
export async function setupPythonViaSystem(version: string, setupDir: string, _arch: string) {
switch (process.platform) {
case "win32": {
setupChocoPack("python3", version, setupDir ? [`--params=/InstallDir:${setupDir}`] : [])
if (setupDir) {
setupChocoPack("python3", version, [`--params=/InstallDir:${setupDir}`])
} else {
setupChocoPack("python3", version)
}
// Adding the bin dir to the path
/** The directory which the tool is installed to */
activateWinPython(setupDir)

View File

@ -7,11 +7,10 @@ import { addPath } from "../path/addPath"
import { setupPython } from "../../python/python"
import { isBinUptoDate } from "./version"
import { join } from "path"
import { isGitHubCI } from "../env/isci"
import { getVersion } from "../../default_versions"
import { untildify_user as untildify } from "../path/untildify"
let pip: string | undefined
let python: string = "python3"
let binDir: string | undefined
@ -19,15 +18,10 @@ let binDir: string | undefined
export async function setupPipPack(name: string, version?: string) {
// setup python and pip if needed
if (pip === undefined) {
if (process.platform === "win32") {
const installationInfo = await setupPython(getVersion("python", undefined), untildify("python"), process.arch)
if (installationInfo?.installDir !== undefined) {
pip = join(installationInfo.installDir, "Scripts", "pip3.exe")
python = join(installationInfo.installDir, "python.exe")
} else {
pip = "pip3"
if (isGitHubCI() && process.platform === "win32") {
// run setupPython in actions_python anyways
await setupPython(getVersion("python", undefined), "", process.arch)
}
} else {
if (which.sync("pip3", { nothrow: true }) !== null) {
pip = "pip3"
} else if (which.sync("pip", { nothrow: true }) !== null && (await isBinUptoDate("python", "3.0.0"))) {
@ -37,7 +31,6 @@ export async function setupPipPack(name: string, version?: string) {
pip = "pip3"
}
}
}
execa.sync(pip, ["install", version !== undefined && version !== "" ? `${name}==${version}` : name], {
stdio: "inherit",
@ -52,7 +45,7 @@ export async function setupPipPack(name: string, version?: string) {
// windows or others
try {
binDir = join(
(await getExecOutput(`${python} -c "import sys;print(sys.base_exec_prefix);"`)).stdout.trim(),
(await getExecOutput(`python3 -c "import sys;print(sys.base_exec_prefix);"`)).stdout.trim(),
"Scripts"
)
} catch {