1
0
mirror of https://github.com/fedora-python/tox-current-env.git synced 2025-01-26 22:56:15 +01:00

Own executor is not needed if we can override config

This commit is contained in:
Lumir Balhar 2021-12-13 09:20:38 +01:00 committed by Miro Hrončok
parent 46fd9f0865
commit d6cb357233

View File

@ -6,8 +6,9 @@ import warnings
from pathlib import Path
from typing import Set
from tox.config.loader.memory import MemoryLoader
from tox.execute.api import Execute
from tox.execute.local_sub_process import LocalSubProcessExecuteInstance
from tox.execute.local_sub_process import LocalSubProcessExecutor
from tox.plugin import impl
from tox.report import HandledError
from tox.tox_env.python.api import PythonInfo
@ -74,6 +75,14 @@ def tox_add_core_config(core_conf, config):
config.options.default_runner = "virtualenv"
@impl
def tox_add_env_config(env_conf, config):
# This allows all external commands.
# All of them are extenal for us.
loader = MemoryLoader(allowlist_externals=["*"])
config.core.loaders.insert(0, loader)
class CurrentEnv(PythonRun):
def __init__(self, create_args):
self._executor = None
@ -100,7 +109,7 @@ class CurrentEnv(PythonRun):
@property
def executor(self):
if self._executor is None:
self._executor = CurrentEnvRunExecutor(self.options.is_colored)
self._executor = LocalSubProcessExecutor(self.options.is_colored)
return self._executor
def _get_python(self, base_python):
@ -149,20 +158,6 @@ class CurrentEnv(PythonRun):
return sys.platform
class CurrentEnvRunExecutor(Execute):
def build_instance(
self,
request,
options,
out,
err,
):
# Disable check for the external commands,
# all of them are external for us.
request.allow = None
return LocalSubProcessExecuteInstance(request, options, out, err)
class PrintEnv(CurrentEnv):
def __init__(self, create_args):
super().__init__(create_args)