New submission from Scott Dial <sc...@scottdial.com>:

The code in as_completed() waits on a FIRST_COMPLETED event, which means that 
after the first future completes, it will no longer wait at all. The proposed 
patch adds a _AsCompletedWaiter and uses a lock to swap out the finished list 
and reset the event.

This is a difficult problem to create a test case for without adding intrusive 
code to as_completed() to count how many times it loops or create a mock Event 
object that counts it, so I have not proposed a test.

----------
components: Library (Lib)
files: futures-r86476.patch
keywords: patch
messages: 121280
nosy: scott.dial
priority: normal
severity: normal
status: open
title: concurrent.futures.as_completed() spins waiting for futures to complete
type: behavior
versions: Python 3.2, Python 3.3
Added file: http://bugs.python.org/file19615/futures-r86476.patch

_______________________________________
Python tracker <rep...@bugs.python.org>
<http://bugs.python.org/issue10432>
_______________________________________
_______________________________________________
Python-bugs-list mailing list
Unsubscribe: 
http://mail.python.org/mailman/options/python-bugs-list/archive%40mail-archive.com

Reply via email to