[New-bugs-announce] [issue31450] Subprocess exceptions re-raised in parent process do not have child_traceback attribute
Michal Sekletar
report at bugs.python.org
Wed Sep 13 08:25:50 EDT 2017
New submission from Michal Sekletar:
Issue
-----
Documentation of subprocess module claims that exceptions raised in child process will be re-raised in the parent process and will have child_traceback attribute set [1]. At least on Fedora Rawhide with python-3.6.2 this is not the case.
Reproducer
----------
$ cat preexec-exception.py
#!/usr/bin/env python3
import subprocess
class PreExecCallback:
def __call__(self):
raise Exception()
if __name__ == "__main__":
p = PreExecCallback()
try:
subprocess.Popen(['/bin/echo', 'foobar'], preexec_fn=p)
except subprocess.SubprocessError as e:
if not hasattr(e, 'child_traceback'):
print('BUG: Exception happened in child, but exception object does not have child_traceback attribute')
Actual result
-------------
$ ./preexec-exception.py
BUG: Exception happened in child, but exception object does not have child_traceback attribute
Expected result
---------------
No output, because child_traceback attribute is present
Additional info
---------------
I happened to notice this while working with pre-exec callbacks. However, according to https://stackoverflow.com/questions/38433837/subprocess-child-traceback this seems to be the generic problem.
[1] https://docs.python.org/3/library/subprocess.html#exceptions
----------
components: Library (Lib)
messages: 302064
nosy: msekletar
priority: normal
severity: normal
status: open
title: Subprocess exceptions re-raised in parent process do not have child_traceback attribute
type: behavior
versions: Python 3.6
_______________________________________
Python tracker <report at bugs.python.org>
<https://bugs.python.org/issue31450>
_______________________________________
More information about the New-bugs-announce
mailing list