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
In multiprocessing.pool, ExceptionWithTraceback should derive from Exception #65179
Comments
In multiprocessing.pool, ExceptionWithTraceback is not derived from Exception. Thus when it is raised, we get the exception, "TypeError: exceptions must derive from BaseException". Attached is a patch that fixes this. See below example traceback that prompted me to notice this: Traceback (most recent call last):
File "/Users/myint/Library/Python/3.4/bin/yolk", line 9, in <module>
load_entry_point('yolk3k==0.7.3', 'console_scripts', 'yolk')()
File "/Users/myint/Library/Python/3.4/lib/python/site-packages/yolk/cli.py", line 1123, in main
my_yolk.run()
File "/Users/myint/Library/Python/3.4/lib/python/site-packages/yolk/cli.py", line 208, in run
return getattr(self, action)()
File "/Users/myint/Library/Python/3.4/lib/python/site-packages/yolk/cli.py", line 240, in show_updates
for (project_name, version, newest) in _updates(pkg_list, self.pypi):
File "/Users/myint/Library/Python/3.4/lib/python/site-packages/yolk/cli.py", line 1104, in _updates
names):
File "/opt/local/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/multiprocessing/pool.py", line 255, in map
return self._map_async(func, iterable, mapstar, chunksize).get()
File "/opt/local/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/multiprocessing/pool.py", line 594, in get
raise self._value
TypeError: exceptions must derive from BaseException |
We must have a missing test case, then. One should be added. |
I didn't quite understand the multiprocessing test cases, but attached is a standalone test case that reproduces the problem. The problem only shows up when using ThreadPool. $ python thread_pool_exception_test.py
Traceback (most recent call last):
File "thread_pool_exception_test.py", line 7, in <module>
pool.map(exception, [1])
File "/opt/local/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/multiprocessing/pool.py", line 255, in map
return self._map_async(func, iterable, mapstar, chunksize).get()
File "/opt/local/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/multiprocessing/pool.py", line 594, in get
raise self._value
TypeError: exceptions must derive from BaseException |
This bug was introduced in bpo-13831. |
We should only wrap the exception with ExceptionWithTraceback in the process case where it will be pickled and then unpickled. |
New changeset df6a6951b2c9 by Richard Oudkerk in branch '3.4': |
Note: these values reflect the state of the issue at the time it was migrated and might not reflect the current state.
Show more details
GitHub fields:
bugs.python.org fields:
The text was updated successfully, but these errors were encountered: