From e70758eccc0531f98be30a6afe1300aeabaae688 Mon Sep 17 00:00:00 2001 From: Andrew Kroh Date: Tue, 12 Mar 2019 11:53:15 -0400 Subject: [PATCH] Use PYTHON_EXE env var as the python interpreter Setting the PYTHON_EXE environment variable causes new Python virtual environments to be created using the specified interpreter. Both `make` and `mage` honor the variable. For example, `PYTHON_EXE=python2.7 make python-env`. Add changelog --- CHANGELOG-developer.next.asciidoc | 2 ++ dev-tools/mage/pytest.go | 11 +++++++++-- libbeat/scripts/Makefile | 2 +- 3 files changed, 12 insertions(+), 3 deletions(-) diff --git a/CHANGELOG-developer.next.asciidoc b/CHANGELOG-developer.next.asciidoc index ee7bf7729c16..0e01df75470c 100644 --- a/CHANGELOG-developer.next.asciidoc +++ b/CHANGELOG-developer.next.asciidoc @@ -37,3 +37,5 @@ The list below covers the major changes between 7.0.0-beta1 and master only. - Support for Logger in the Metricset base instance. {pull}11106[11106] - Introduce processing.Support to instance.Setting. This allows Beats to fully modify the event processing. {pull}10801[10801] - Filebeat modules can now use ingest pipelines in YAML format. {pull}11209[11209] +- Added support for using PYTHON_EXE to control what Python interpreter is used + by `make` and `mage`. Example: `export PYTHON_EXE=python2.7`. {pull}11212[11212] diff --git a/dev-tools/mage/pytest.go b/dev-tools/mage/pytest.go index 9aaf8a4b4e80..cdcce4c61668 100644 --- a/dev-tools/mage/pytest.go +++ b/dev-tools/mage/pytest.go @@ -167,10 +167,17 @@ func PythonVirtualenv() (string, error) { return pythonVirtualenvDir, nil } + // If set use PYTHON_EXE env var as the python interpreter. + var args []string + if pythonExe := os.Getenv("PYTHON_EXE"); pythonExe != "" { + args = append(args, "-p", pythonExe) + } + args = append(args, ve) + // Execute virtualenv. if _, err := os.Stat(ve); err != nil { // Run virtualenv if the dir does not exist. - if err := sh.Run("virtualenv", ve); err != nil { + if err := sh.Run("virtualenv", args...); err != nil { return "", err } } @@ -181,7 +188,7 @@ func PythonVirtualenv() (string, error) { } pip := virtualenvPath(ve, "pip") - args := []string{"install"} + args = []string{"install"} if !mg.Verbose() { args = append(args, "--quiet") } diff --git a/libbeat/scripts/Makefile b/libbeat/scripts/Makefile index 5ab4a3e72337..a007eca7b299 100755 --- a/libbeat/scripts/Makefile +++ b/libbeat/scripts/Makefile @@ -250,7 +250,7 @@ load-tests: ## @testing Runs load tests # Sets up the virtual python environment .PHONY: python-env python-env: ${ES_BEATS}/libbeat/tests/system/requirements.txt - @test -d ${PYTHON_ENV} || virtualenv ${VIRTUALENV_PARAMS} ${PYTHON_ENV} + @test -d ${PYTHON_ENV} || virtualenv $(if ${PYTHON_EXE},-p ${PYTHON_EXE}) ${VIRTUALENV_PARAMS} ${PYTHON_ENV} @. ${PYTHON_ENV}/bin/activate && pip install ${PIP_INSTALL_PARAMS} -q --upgrade pip ; \ if [ -a ./tests/system/requirements.txt ] && [ ! ${ES_BEATS}/libbeat/tests/system/requirements.txt -ef ./tests/system/requirements.txt ] ; then \ . ${PYTHON_ENV}/bin/activate && pip install ${PIP_INSTALL_PARAMS} -qUr ${ES_BEATS}/libbeat/tests/system/requirements.txt -Ur ./tests/system/requirements.txt ; \