Skip to content

Conversation

@vfazio
Copy link
Contributor

@vfazio vfazio commented Apr 7, 2025

Add support for disabling the use of posix_spawn via a variable in the process environment.

While it was previously possible to toggle this by modifying the value of subprocess._USE_POSIX_SPAWN, this required either patching CPython or modifying it within the interpreter instance which is not always possible, such as when running applications or scripts not under a user's control.

Add support for disabling the use of `posix_spawn` via a variable in
the process environment.

While it was previously possible to toggle this by modifying the value
of `subprocess._USE_POSIX_SPAWN`, this required either patching CPython
or modifying it within the interpreter instance which is not always
possible, such as when running applications or scripts not under a
user's control.

Signed-off-by: Vincent Fazio <[email protected]>
@vfazio
Copy link
Contributor Author

vfazio commented Apr 7, 2025

vfazio@Zephyrus:~/development/cpython$ _PYTHON_SUBPROCESS_USE_POSIX_SPAWN="0" ./python -c "import subprocess; print(subprocess._USE_POSIX_SPAWN)"
False
vfazio@Zephyrus:~/development/cpython$ _PYTHON_SUBPROCESS_USE_POSIX_SPAWN=0 ./python -c "import subprocess; print(subprocess._USE_POSIX_SPAWN)"
False
vfazio@Zephyrus:~/development/cpython$ _PYTHON_SUBPROCESS_USE_POSIX_SPAWN=1 ./python -c "import subprocess; print(subprocess._USE_POSIX_SPAWN)"
True
vfazio@Zephyrus:~/development/cpython$ _PYTHON_SUBPROCESS_USE_POSIX_SPAWN="" ./python -c "import subprocess; print(subprocess._USE_POSIX_SPAWN)"
True

@gpshead per our discussion in #129204 (comment)

@gpshead gpshead merged commit 4c5dcc6 into python:main Apr 7, 2025
43 checks passed
@gpshead gpshead added the needs backport to 3.13 bugs and security fixes label Apr 7, 2025
@miss-islington-app
Copy link

Thanks @vfazio for the PR, and @gpshead for merging it 🌮🎉.. I'm working now to backport this PR to: 3.13.
🐍🍒⛏🤖

miss-islington pushed a commit to miss-islington/cpython that referenced this pull request Apr 7, 2025
…nob (pythonGH-132184)

* Add _PYTHON_SUBPROCESS_USE_POSIX_SPAWN environment knob

Add support for disabling the use of `posix_spawn` via a variable in
the process environment.

While it was previously possible to toggle this by modifying the value
of `subprocess._USE_POSIX_SPAWN`, this required either patching CPython
or modifying it within the interpreter instance which is not always
possible, such as when running applications or scripts not under a
user's control.

Signed-off-by: Vincent Fazio <[email protected]>

* fixup NEWS entry

---------
(cherry picked from commit 4c5dcc6)

Co-authored-by: Vincent Fazio <[email protected]>
Signed-off-by: Vincent Fazio <[email protected]>
@bedevere-app
Copy link

bedevere-app bot commented Apr 7, 2025

GH-132191 is a backport of this pull request to the 3.13 branch.

@bedevere-app bedevere-app bot removed the needs backport to 3.13 bugs and security fixes label Apr 7, 2025
gpshead pushed a commit that referenced this pull request Apr 7, 2025
…knob (GH-132184) (#132191)

gh-129204: Add _PYTHON_SUBPROCESS_USE_POSIX_SPAWN environment knob (GH-132184)

* Add _PYTHON_SUBPROCESS_USE_POSIX_SPAWN environment knob

Add support for disabling the use of `posix_spawn` via a variable in
the process environment.

While it was previously possible to toggle this by modifying the value
of `subprocess._USE_POSIX_SPAWN`, this required either patching CPython
or modifying it within the interpreter instance which is not always
possible, such as when running applications or scripts not under a
user's control.



* fixup NEWS entry

---------
(cherry picked from commit 4c5dcc6)

Signed-off-by: Vincent Fazio <[email protected]>
Co-authored-by: Vincent Fazio <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants