New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
gh-101283: Try to load the fallback cmd.exe by an absolute path #101286
gh-101283: Try to load the fallback cmd.exe by an absolute path #101286
Conversation
arhadthedev
commented
Jan 24, 2023
•
edited by bedevere-bot
edited by bedevere-bot
- Issue: Undocumented risky behaviour in subprocess module #101283
Looks like a fluke; restarting. |
Co-authored-by: Eryk Sun <eryksun@gmail.com>
Co-authored-by: Eryk Sun <eryksun@gmail.com>
@eryksun Thank you for improvements! Since none of my code is left, I've reattributed the news entry to you. |
Co-authored-by: Eryk Sun <eryksun@gmail.com>
Lib/subprocess.py
Outdated
# cmd.exe is missing, or the system environment | ||
# variables are broken, or they're undefined and the | ||
# system is installed into a non-standard location. | ||
# This is highly unlikely, and we cannot help here. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should a RuntimeWarning be raised or logging.warn call made in this case as an FYI?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
That's a good idea. How about this?
comspec = 'cmd.exe'
warnings.warn(f'spawning "{comspec}" using a '
'relative file path',
RuntimeWarning)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
if we keep the fallback at all rather than just make it an error, something like that. probably with a stacklevel= set.
related to my other comment, i wouldn't want to add a new warning in a security backport either.
Misc/NEWS.d/next/Security/2023-01-24-16-12-00.gh-issue-101283.9tqu39.rst
Outdated
Show resolved
Hide resolved
…ue on Windows (pythonGH-101286) (cherry picked from commit 23751ed) Co-authored-by: Oleg Iarygin <oleg@arhadthedev.net>
Thanks @arhadthedev for the PR, and @zooba for merging it |
Sorry @arhadthedev and @zooba, I had trouble checking out the |
Thanks @arhadthedev for the PR, and @zooba for merging it |
GH-101711 is a backport of this pull request to the 3.11 branch. |
…ue on Windows (pythonGH-101286) (cherry picked from commit 23751ed) Co-authored-by: Oleg Iarygin <oleg@arhadthedev.net>
Bah, just noticed in the backports that now there's a case where |
Turns out I can commit directly to the backports, so those will be fine. But we need an |
GH-101713 is a backport of this pull request to the 3.7 branch. |
GH-101712 is the comspec=executable fix for main. |
@@ -111,6 +111,14 @@ underlying :class:`Popen` interface can be used directly. | |||
Added the *text* parameter, as a more understandable alias of *universal_newlines*. | |||
Added the *capture_output* parameter. | |||
|
|||
.. versionchanged:: 3.11.2 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This version number is wrong. 3.11.2 was released before this change was merged. As this PR is in the main
branch, listing it as 3.12 in these docs is more appropriate. Documentation readers should not be expected to know which patch release versions came before a major release.
We lack the ability to list all versions in versionchanged markers in our docs so have done it this way elsewhere as well when a visible API change has been made in patch releases.
Got working on it; the PR will follow in a few hours. |
To be fixed by gh-101712. Thank you, @zooba!
Addressed in gh-101728. |
* main: (82 commits) pythongh-101670: typo fix in PyImport_ExtendInittab() (python#101723) pythonGH-99293: Document that `Py_TPFLAGS_VALID_VERSION_TAG` shouldn't be used. (#pythonGH-101736) no-issue: Add Dong-hee Na as the cjkcodecs codeowner (pythongh-101731) pythongh-101678: Merge math_1_to_whatever() and math_1() (python#101730) pythongh-101678: refactor the math module to use special functions from c11 (pythonGH-101679) pythongh-85984: Remove legacy Lib/pty.py code. (python#92365) pythongh-98831: Use opcode metadata for stack_effect() (python#101704) pythongh-101283: Version was just released, so should be changed in 3.11.3 (pythonGH-101719) pythongh-101283: Fix use of unbound variable (pythonGH-101712) pythongh-101283: Improved fallback logic for subprocess with shell=True on Windows (pythonGH-101286) pythongh-101277: Port more itertools static types to heap types (python#101304) pythongh-98831: Modernize CALL and family (python#101508) pythonGH-101696: invalidate type version tag in `_PyStaticType_Dealloc` (python#101697) pythongh-100221: Fix creating dirs in `make sharedinstall` (pythonGH-100329) pythongh-101670: typo fix in PyImport_AppendInittab() (pythonGH-101672) pythongh-101196: Make isdir/isfile/exists faster on Windows (pythonGH-101324) pythongh-101614: Don't treat python3_d.dll as a Python DLL when checking extension modules for incompatibility (pythonGH-101615) pythongh-100933: Improve `check_element` helper in `test_xml_etree` (python#100934) pythonGH-101578: Normalize the current exception (pythonGH-101607) pythongh-47937: Note that Popen attributes are read-only (python#93070) ...