This issue tracker has been migrated to GitHub, and is currently read-only.
For more information, see the GitHub FAQs in the Python's Developer Guide.

classification
Title: subprocess on Windows: wrong return code with shell=True
Type: behavior Stage: needs patch
Components: Versions:
process
Status: open Resolution:
Dependencies: Superseder:
Assigned To: Nosy List: eryksun, ezio.melotti, giampaolo.rodola, gvanrossum
Priority: low Keywords:

Created on 2014-01-03 22:20 by gvanrossum, last changed 2022-04-11 14:57 by admin.

Messages (3)
msg207251 - (view) Author: Guido van Rossum (gvanrossum) * (Python committer) Date: 2014-01-03 22:20
A little birdie told me:

"""
Bug in Python subprocess doesn't allow to detect if
command executed through Windows system shell
exists.

If command doesn't exist, windows shell returns 9009
exit code (127 on Linux):
---[a.bat]---
@echo off
nonex
echo %ERRORLEVEL%

> a.bat
'nonex' is not recognized as an internal or external command,
operable program or batch file.
9009

However, when executed with Python, the return code
is different on Python 2.7/3.3:
---[x.py]---
import subprocess
p = subprocess.Popen("nonex", shell=True)
print(p.wait())

> python x.py
'nonex' is not recognized as an internal or external command,
operable program or batch file.
1

The same script executed on Linux gives correct result:
# python x.py
/bin/sh: non-existent: command not found
127

---[a.sh]---
nonex
echo $?
"""

There's some more research at http://goo.gl/xEg2b1

Seems the culprit is cmd.exe, which is executed by Python internally.
It looks like it fails to return corresponding code 9009.

Possibly all that needs to be done is documenting this wart, if we can't do anything about it?
msg222896 - (view) Author: Mark Lawrence (BreamoreBoy) * Date: 2014-07-12 23:55
Can our Windows gurus advise on this please.
msg223072 - (view) Author: Eryk Sun (eryksun) * (Python triager) Date: 2014-07-15 01:24
For what it's worth, an explicit "exit" will set the return code to the last error.

    >>> subprocess.call("nonex & exit", shell=True, stderr=subprocess.DEVNULL)          
    9009
History
Date User Action Args
2022-04-11 14:57:56adminsetgithub: 64316
2019-04-26 19:33:56BreamoreBoysetnosy: - BreamoreBoy
2014-07-15 01:24:42eryksunsetnosy: + eryksun
messages: + msg223072
2014-07-13 00:02:41brian.curtinsetnosy: - brian.curtin
2014-07-12 23:55:31BreamoreBoysetnosy: + BreamoreBoy
messages: + msg222896
2014-01-04 00:18:25ezio.melottisetnosy: + giampaolo.rodola, brian.curtin
2014-01-03 22:20:39gvanrossumcreate