Merge "Rewrite rally.utils.sync_execute() to wait_for()"

This commit is contained in:
Jenkins 2013-10-10 21:53:34 +00:00 committed by Gerrit Code Review
commit 69ec96ca71
2 changed files with 29 additions and 31 deletions

View File

@ -126,32 +126,28 @@ def import_modules_from_package(package):
try_append_module(module_name, sys.modules) try_append_module(module_name, sys.modules)
def sync_execute(func, args, kwargs, is_ready, update_result=None, def wait_for(resource, is_ready, update_resource=None, timeout=60, sleep=1):
timeout=60, sleep=1): """Waits for the given resource to come into the desired state.
"""Wraps an asynchronous function call into a synchronous one. Assumes that
the called function immediately returns an object for which it takes some
time to get to the 'ready for use' state.
:param func: Asynchronous function to be called Uses the readiness check function passed as a parameter and (optionally)
:param args: List of args for the function to be called with a function that updates the resource being waited for.
:param kwargs: Dict of named args for the function to be called with
:param is_ready: A predicate that should take the func(**kwarg) execution :param is_ready: A predicate that should take the resource object and
result and return True iff it is ready to be returned return True iff it is ready to be returned
:param update_result: Function that should take the func(**kwarg) execution :param update_resource: Function that should take the resource object
result and return an 'updated' result. If set to and return an 'updated' resource. If set to
None, no result updating is performed None, no result updating is performed
:param timeout: Timeout in seconds after which a TimeoutException will be :param timeout: Timeout in seconds after which a TimeoutException will be
raised raised
:param sleep: Pause in seconds between the two consecutive readiness checks :param sleep: Pause in seconds between the two consecutive readiness checks
:returns: The 'ready for use' result of func(*args, **kwargs) function call :returns: The "ready" resource object
""" """
start = time.time() start = time.time()
result = func(*args, **kwargs) while not is_ready(resource):
while not is_ready(result):
time.sleep(sleep) time.sleep(sleep)
if time.time() - start > timeout: if time.time() - start > timeout:
raise exceptions.TimeoutException() raise exceptions.TimeoutException()
if update_result: if update_resource:
result = update_result(result) resource = update_resource(resource)
return result return resource

View File

@ -145,24 +145,26 @@ class ImportModulesTestCase(test.NoDBTestCase):
self.assertTrue('tests.fixtures.import.package.b' in sys.modules) self.assertTrue('tests.fixtures.import.package.b' in sys.modules)
class SyncExecuteTestCase(test.NoDBTestCase): class WaitForTestCase(test.NoDBTestCase):
def test_sync_execute(self): def test_wait_for(self):
def fake_factory(): def get_fake_checker_delayed(**delay):
return object() deadline = datetime.datetime.now() + datetime.timedelta(**delay)
return lambda obj: datetime.datetime.now() > deadline
def fake_checker_based_on_time(obj): def fake_checker_false(obj):
return datetime.datetime.now().microsecond > 500000
def fake_checker_always_false(obj):
return False return False
def fake_updater(obj): def fake_updater(obj):
return obj return obj
utils.sync_execute(fake_factory, [], {}, fake_checker_based_on_time, resource = object()
fake_updater, 1, 0.2) fake_checker_delayed = get_fake_checker_delayed(seconds=0.5)
self.assertRaises(exceptions.TimeoutException, utils.sync_execute,
fake_factory, [], {}, fake_checker_always_false, loaded_resource = utils.wait_for(resource, fake_checker_delayed,
fake_updater, 0.3, 0.1) fake_updater, 1, 0.2)
self.assertEqual(loaded_resource, resource)
self.assertRaises(exceptions.TimeoutException, utils.wait_for,
object(), fake_checker_false, fake_updater, 0.3, 0.1)