Merge "Update to the lastest loopingcall from oslo."

This commit is contained in:
Jenkins 2013-04-09 15:20:16 +00:00 committed by Gerrit Code Review
commit 8319ab1c82
2 changed files with 59 additions and 7 deletions

View File

@ -46,12 +46,23 @@ class LoopingCallDone(Exception):
self.retvalue = retvalue self.retvalue = retvalue
class LoopingCall(object): class LoopingCallBase(object):
def __init__(self, f=None, *args, **kw): def __init__(self, f=None, *args, **kw):
self.args = args self.args = args
self.kw = kw self.kw = kw
self.f = f self.f = f
self._running = False self._running = False
self.done = None
def stop(self):
self._running = False
def wait(self):
return self.done.wait()
class FixedIntervalLoopingCall(LoopingCallBase):
"""A fixed interval looping call."""
def start(self, interval, initial_delay=None): def start(self, interval, initial_delay=None):
self._running = True self._running = True
@ -77,7 +88,7 @@ class LoopingCall(object):
self.stop() self.stop()
done.send(e.retvalue) done.send(e.retvalue)
except Exception: except Exception:
LOG.exception(_('in looping call')) LOG.exception(_('in fixed duration looping call'))
done.send_exception(*sys.exc_info()) done.send_exception(*sys.exc_info())
return return
else: else:
@ -88,8 +99,49 @@ class LoopingCall(object):
greenthread.spawn_n(_inner) greenthread.spawn_n(_inner)
return self.done return self.done
def stop(self):
self._running = False
def wait(self): # TODO(mikal): this class name is deprecated in Havana and should be removed
return self.done.wait() # in the I release
LoopingCall = FixedIntervalLoopingCall
class DynamicLoopingCall(LoopingCallBase):
"""A looping call which sleeps until the next known event.
The function called should return how long to sleep for before being
called again.
"""
def start(self, initial_delay=None, periodic_interval_max=None):
self._running = True
done = event.Event()
def _inner():
if initial_delay:
greenthread.sleep(initial_delay)
try:
while self._running:
idle = self.f(*self.args, **self.kw)
if not self._running:
break
if periodic_interval_max is not None:
idle = min(idle, periodic_interval_max)
LOG.debug(_('Dynamic looping call sleeping for %.02f '
'seconds'), idle)
greenthread.sleep(idle)
except LoopingCallDone, e:
self.stop()
done.send(e.retvalue)
except Exception:
LOG.exception(_('in dynamic looping call'))
done.send_exception(*sys.exc_info())
return
else:
done.send(True)
self.done = done
greenthread.spawn(_inner)
return self.done

View File

@ -63,7 +63,7 @@ class ThreadGroup(object):
def add_timer(self, interval, callback, initial_delay=None, def add_timer(self, interval, callback, initial_delay=None,
*args, **kwargs): *args, **kwargs):
pulse = loopingcall.LoopingCall(callback, *args, **kwargs) pulse = loopingcall.FixedIntervalLoopingCall(callback, *args, **kwargs)
pulse.start(interval=interval, pulse.start(interval=interval,
initial_delay=initial_delay) initial_delay=initial_delay)
self.timers.append(pulse) self.timers.append(pulse)