cpython/Lib/concurrent/futures
Sean 904e34d4e6 bpo-24882: Let ThreadPoolExecutor reuse idle threads before creating new thread (#6375)
* Fixes issue 24882

* Add news file entry for change.

* Change test_concurrent_futures.ThreadPoolShutdownTest

Adjust the shutdown test so that, after submitting three jobs
to the executor, the test checks for less than three threads,
instead of looking for exactly three threads.

If idle threads are being recycled properly, then we should have
less than three threads.

* Switched idle count to semaphor, Updated tests

As suggested by reviewer tomMoral, swapped lock-protected counter
with a semaphore to track the number of unused threads.

Adjusted test_threads_terminate to wait for completiton of the
previous future before submitting a new one (and checking the
number of threads used).

Also added a new test to confirm the thread pool can be saturated.

* Updates tests as requested by pitrou.

* Correct minor whitespace error.

* Make test_saturation faster
2019-05-22 23:29:58 +02:00
..
__init__.py bpo-33238: Add InvalidStateError to concurrent.futures. (GH-7056) 2018-05-30 10:15:06 +03:00
_base.py bpo-33110: Catch errors raised when running add_done_callback on already completed futures (GH-13141) 2019-05-22 23:29:02 +02:00
process.py bpo-26903: Limit ProcessPoolExecutor to 61 workers on Windows (GH-13132) 2019-05-08 14:04:53 -04:00
thread.py bpo-24882: Let ThreadPoolExecutor reuse idle threads before creating new thread (#6375) 2019-05-22 23:29:58 +02:00