From 93eb0febc7e46121f4d7baca921085cb7b19b729 Mon Sep 17 00:00:00 2001
From: Joshua Harlow <harlowja@yahoo-inc.com>
Date: Tue, 14 Jul 2015 11:39:56 -0700
Subject: [PATCH] Fully use futurist code-base to abstract concurrent.futures
 away

Change-Id: Iafa789f20d1ac365fe9da2ede2b2fa03a3b8720f
---
 oslo_messaging/_executors/impl_pooledexecutor.py |  6 ++----
 requirements.txt                                 | 12 ------------
 2 files changed, 2 insertions(+), 16 deletions(-)

diff --git a/oslo_messaging/_executors/impl_pooledexecutor.py b/oslo_messaging/_executors/impl_pooledexecutor.py
index 68743368c..598229c07 100644
--- a/oslo_messaging/_executors/impl_pooledexecutor.py
+++ b/oslo_messaging/_executors/impl_pooledexecutor.py
@@ -15,10 +15,9 @@
 #    under the License.
 
 import collections
-import functools
 import threading
 
-from concurrent import futures
+from futurist import waiters
 from oslo_config import cfg
 from oslo_utils import excutils
 
@@ -54,8 +53,7 @@ class PooledExecutor(base.ExecutorBase):
     _executor_cls = None
 
     # Blocking function that should wait for all provided futures to finish.
-    _wait_for_all = functools.partial(futures.wait,
-                                      return_when=futures.ALL_COMPLETED)
+    _wait_for_all = staticmethod(waiters.wait_for_all)
 
     def __init__(self, conf, listener, dispatcher):
         super(PooledExecutor, self).__init__(conf, listener, dispatcher)
diff --git a/requirements.txt b/requirements.txt
index 1ec26bf2a..764d699d1 100644
--- a/requirements.txt
+++ b/requirements.txt
@@ -37,18 +37,6 @@ kombu>=3.0.7
 # middleware
 oslo.middleware>=2.4.0 # Apache-2.0
 
-# FIXME: concurrent.futures is part of the Python stdlib since Python 3.2,
-# but the requirements is still needed because of a bug in tox:
-# https://bitbucket.org/hpk42/tox/issue/236/tox-must-create-the-source-distribution
-#
-# Tox builds a source distribution with "python setup.py sdist" which uses
-# requirements.txt even if tox wants to build the py34 virtual environment.
-# As a consequence, oslo.messaging.egg_info/requires.txt contains futures
-# and oslo_messaging.tests.test_opts.OptsTestCase.test_entry_point fails.
-#
-# for the futures based executor
-futures>=3.0;python_version=='2.7' or python_version=='2.6'
-
 # needed by the aioeventlet executor
 aioeventlet>=0.4
 trollius>=1.0