Description
Issue
I'm trying to do some Python development on an Android phone. I pkg install python pipx
, I pipx install tox
, and when I run tox
, I get this traceback from inside virtualenv's Python interpreter discovery code:
$ tox
Traceback (most recent call last):
File "/data/data/com.termux/files/home/.local/bin/tox", line 8, in <module>
sys.exit(run())
^^^^^
File "/data/data/com.termux/files/home/.local/pipx/venvs/tox/lib/python3.12/site-packages/tox/run.py", line 20, in run
result = main(sys.argv[1:] if args is None else args)
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
File "/data/data/com.termux/files/home/.local/pipx/venvs/tox/lib/python3.12/site-packages/tox/run.py", line 46, in main
return handler(state)
^^^^^^^^^^^^^^
File "/data/data/com.termux/files/home/.local/pipx/venvs/tox/lib/python3.12/site-packages/tox/session/cmd/legacy.py", line 115, in legacy
return run_sequential(state)
^^^^^^^^^^^^^^^^^^^^^
File "/data/data/com.termux/files/home/.local/pipx/venvs/tox/lib/python3.12/site-packages/tox/session/cmd/run/sequential.py", line 25, in run_sequential
return execute(state, max_workers=1, has_spinner=False, live=True)
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
File "/data/data/com.termux/files/home/.local/pipx/venvs/tox/lib/python3.12/site-packages/tox/session/cmd/run/common.py", line 167, in execute
state.envs.ensure_only_run_env_is_active()
File "/data/data/com.termux/files/home/.local/pipx/venvs/tox/lib/python3.12/site-packages/tox/session/env_select.py", line 436, in ensure_only_run_env_is_active
envs, active = self._defined_envs, self._env_name_to_active()
^^^^^^^^^^^^^^^^^^
File "/data/data/com.termux/files/home/.local/pipx/venvs/tox/lib/python3.12/site-packages/tox/session/env_select.py", line 291, in _defined_envs
raise failed[next(iter(failed_to_create))]
File "/data/data/com.termux/files/home/.local/pipx/venvs/tox/lib/python3.12/site-packages/tox/session/env_select.py", line 268, in _defined_envs
run_env.package_env = self._build_pkg_env(pkg_name_type, name, env_name_to_active)
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
File "/data/data/com.termux/files/home/.local/pipx/venvs/tox/lib/python3.12/site-packages/tox/session/env_select.py", line 340, in _build_pkg_env
name_type = next(child_package_envs)
^^^^^^^^^^^^^^^^^^^^^^^^
File "/data/data/com.termux/files/home/.local/pipx/venvs/tox/lib/python3.12/site-packages/tox/tox_env/python/virtual_env/package/pyproject.py", line 191, in register_run_env
yield from super().register_run_env(run_env)
File "/data/data/com.termux/files/home/.local/pipx/venvs/tox/lib/python3.12/site-packages/tox/tox_env/python/package.py", line 117, in register_run_env
pkg_env = run_env.conf["wheel_build_env"]
~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^
File "/data/data/com.termux/files/home/.local/pipx/venvs/tox/lib/python3.12/site-packages/tox/config/sets.py", line 116, in __getitem__
return self.load(item)
^^^^^^^^^^^^^^^
File "/data/data/com.termux/files/home/.local/pipx/venvs/tox/lib/python3.12/site-packages/tox/config/sets.py", line 127, in load
return config_definition.__call__(self._conf, self.loaders, ConfigLoadArgs(chain, self.name, self.env_name)) # noqa: PLC2801
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
File "/data/data/com.termux/files/home/.local/pipx/venvs/tox/lib/python3.12/site-packages/tox/config/of_type.py", line 117, in __call__
value = self.default(conf, args.env_name) if callable(self.default) else self.default
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
File "/data/data/com.termux/files/home/.local/pipx/venvs/tox/lib/python3.12/site-packages/tox/tox_env/python/package.py", line 93, in default_wheel_tag
run_py = cast(Python, run_env).base_python
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
File "/data/data/com.termux/files/home/.local/pipx/venvs/tox/lib/python3.12/site-packages/tox/tox_env/python/api.py", line 282, in base_python
self._base_python = self._get_python(base_pythons)
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
File "/data/data/com.termux/files/home/.local/pipx/venvs/tox/lib/python3.12/site-packages/tox/tox_env/python/virtual_env/api.py", line 139, in _get_python
interpreter = self.creator.interpreter
^^^^^^^^^^^^
File "/data/data/com.termux/files/home/.local/pipx/venvs/tox/lib/python3.12/site-packages/tox/tox_env/python/virtual_env/api.py", line 131, in creator
return self.session.creator
^^^^^^^^^^^^
File "/data/data/com.termux/files/home/.local/pipx/venvs/tox/lib/python3.12/site-packages/tox/tox_env/python/virtual_env/api.py", line 112, in session
self._virtualenv_session = session_via_cli(env_dir, options=None, setup_logging=False, env=env)
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
File "/data/data/com.termux/files/home/.local/pipx/venvs/tox/lib/python3.12/site-packages/virtualenv/run/__init__.py", line 49, in session_via_cli
parser, elements = build_parser(args, options, setup_logging, env)
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
File "/data/data/com.termux/files/home/.local/pipx/venvs/tox/lib/python3.12/site-packages/virtualenv/run/__init__.py", line 77, in build_parser
parser._interpreter = interpreter = discover.interpreter # noqa: SLF001
^^^^^^^^^^^^^^^^^^^^
File "/data/data/com.termux/files/home/.local/pipx/venvs/tox/lib/python3.12/site-packages/virtualenv/discovery/discover.py", line 41, in interpreter
self._interpreter = self.run()
^^^^^^^^^^
File "/data/data/com.termux/files/home/.local/pipx/venvs/tox/lib/python3.12/site-packages/virtualenv/discovery/builtin.py", line 59, in run
result = get_interpreter(python_spec, self.try_first_with, self.app_data, self._env)
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
File "/data/data/com.termux/files/home/.local/pipx/venvs/tox/lib/python3.12/site-packages/virtualenv/discovery/builtin.py", line 76, in get_interpreter
for interpreter, impl_must_match in propose_interpreters(spec, try_first_with, app_data, env):
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
File "/data/data/com.termux/files/home/.local/pipx/venvs/tox/lib/python3.12/site-packages/virtualenv/discovery/builtin.py", line 150, in propose_interpreters
for exe, impl_must_match in find_candidates(path):
^^^^^^^^^^^^^^^^^^^^^
File "/data/data/com.termux/files/home/.local/pipx/venvs/tox/lib/python3.12/site-packages/virtualenv/discovery/builtin.py", line 210, in path_exes
for exe in path.iterdir():
^^^^^^^^^^^^^^
File "/data/data/com.termux/files/usr/lib/python3.12/pathlib.py", line 1056, in iterdir
for name in os.listdir(self):
^^^^^^^^^^^^^^^^
PermissionError: [Errno 13] Permission denied: '/system_ext/bin'
(I originally filed this as a tox bug, but, well, the crashing code is virtualenv's.
Environment
Provide at least:
-
OS: Android 14, Termux version "googleplay.2024.10.30".
-
pip list
of the host python wherevirtualenv
is installed:
$ pipx runpip tox list
Package Version
cachetools 5.5.0
chardet 5.2.0
colorama 0.4.6
distlib 0.3.9
filelock 3.16.1
packaging 24.1
pip 24.3.1
platformdirs 4.3.6
pluggy 1.5.0
pyproject-api 1.8.0
tox 4.23.2
virtualenv 20.27.
**Output of the virtual environment creation**
This is difficult, as when I run virtualenv myself, it works fine. When pipx runs virtualenv, it works fine. When *tox* runs virtualenv, it crashes -- and I've no idea how to ask tox to please run virtualenv with `-vvv --with-traceback`.
Well, there is a traceback at least. And the cause is pretty obvious: my $PATH contains a directory that is not accessible to the user running virtualenv.
My $PATH is
```console
$ echo $PATH | tr : '\n'
/data/data/com.termux/files/home/bin
/data/data/com.termux/files/home/bin/local
/data/data/com.termux/files/home/.local/bin
/usr/games
/usr/local/sbin
/usr/local/bin
/usr/sbin
/sbin
/data/data/com.termux/files/usr/bin
/product/bin
/apex/com.android.runtime/bin
/apex/com.android.art/bin
/system_ext/bin
/system/bin
/system/xbin
/odm/bin
/vendor/bin
/vendor/xbin
$ ls -ld /system_ext/bin
drwxr-x--x. 3 root shell 4096 Jan 1 2009 /system_ext/bin
I have no idea why Termux puts an inaccessible directory on the default PATH, but it would be helpful if virtualenv's interpreter discovery would skip it instead of failing entirely.
(I have another Android device - a Nokia N20 tablet with Android 13. Tox and virtualenv work fine on it in Termux 0.118.0. The default $PATH is shorter and doesn't mention /system_ext)