mirror of
https://github.com/github/codeql-action.git
synced 2025-12-26 01:00:20 +08:00
Merge pull request #1257 from github/rasmuswl/fix-ubuntu22.04-venv-creation
python-setup: Fix venv creation in Ubuntu 22.04
This commit is contained in:
@@ -5,6 +5,7 @@ import os
|
||||
import subprocess
|
||||
from tempfile import mkdtemp
|
||||
from typing import Optional
|
||||
import shutil
|
||||
|
||||
import extractor_version
|
||||
|
||||
@@ -167,6 +168,19 @@ def install_packages(codeql_base_dir) -> Optional[str]:
|
||||
|
||||
# get_extractor_version returns the Python version the extractor thinks this repo is using
|
||||
version = extractor_version.get_extractor_version(codeql_base_dir, quiet=False)
|
||||
sys.stdout.flush()
|
||||
sys.stderr.flush()
|
||||
|
||||
if version == 2 and not sys.platform.startswith('win32'):
|
||||
# On Ubuntu 22.04 'python2' is not available by default. We want to give a slightly better
|
||||
# error message than a traceback + `No such file or directory: 'python2'`
|
||||
if shutil.which("python2") is None:
|
||||
sys.exit(
|
||||
"Python package installation failed: we detected this code as Python 2, but the 'python2' executable was not available. "
|
||||
"To enable automatic package installation, please install 'python2' before the 'github/codeql-action/init' step, "
|
||||
"for example by running 'sudo apt install python2' (Ubuntu 22.04). "
|
||||
"If your code is not Python 2, but actually Python 3, please file a bug report at https://github.com/github/codeql-action/issues/new"
|
||||
)
|
||||
|
||||
if os.path.exists('requirements.txt'):
|
||||
print('Found requirements.txt, will install packages with pip', flush=True)
|
||||
|
||||
@@ -1,7 +1,11 @@
|
||||
#! /usr/bin/pwsh
|
||||
|
||||
py -2 -m pip install --user --upgrade pip setuptools wheel
|
||||
py -3 -m pip install --user --upgrade pip setuptools wheel
|
||||
# while waiting for the next release of `virtualenv` after v20.16.5, we install an older
|
||||
# version of `setuptools` to ensure that binaries are always put under
|
||||
# `<venv-path>/bin`, which wouldn't always happen with the GitHub actions version of
|
||||
# Ubuntu 22.04. See https://github.com/github/codeql-action/issues/1249
|
||||
py -2 -m pip install --user --upgrade pip 'setuptools<60' wheel
|
||||
py -3 -m pip install --user --upgrade pip 'setuptools<60' wheel
|
||||
|
||||
# virtualenv is a bit nicer for setting up virtual environment, since it will provide up-to-date versions of
|
||||
# pip/setuptools/wheel which basic `python3 -m venv venv` won't
|
||||
|
||||
@@ -11,7 +11,13 @@ set -e
|
||||
export PATH="$HOME/.local/bin:$PATH"
|
||||
|
||||
# Setup Python 3 dependency installation tools.
|
||||
python3 -m pip install --user --upgrade pip setuptools wheel
|
||||
|
||||
# we install an older version of `setuptools` to ensure that binaries are always put
|
||||
# under `<venv-path>/bin`, which wouldn't always happen with the GitHub actions version
|
||||
# of Ubuntu 22.04. See https://github.com/github/codeql-action/issues/1249. The the next
|
||||
# release of `virtualenv` after v20.16.5 will include a fix for this, so we can remove
|
||||
# this bit of the logic again.
|
||||
python3 -m pip install --user --upgrade pip 'setuptools<60' wheel
|
||||
|
||||
# virtualenv is a bit nicer for setting up virtual environment, since it will provide up-to-date versions of
|
||||
# pip/setuptools/wheel which basic `python3 -m venv venv` won't
|
||||
@@ -39,7 +45,7 @@ if command -v python2 >/dev/null 2>&1; then
|
||||
curl --location --fail https://bootstrap.pypa.io/pip/2.7/get-pip.py | python2
|
||||
fi
|
||||
|
||||
python2 -m pip install --user --upgrade pip setuptools wheel
|
||||
python2 -m pip install --user --upgrade pip 'setuptools<60' wheel
|
||||
|
||||
python2 -m pip install --user 'virtualenv!=20.12.0'
|
||||
fi
|
||||
|
||||
Reference in New Issue
Block a user