diff options
| author | Jenkins <jenkins@review.openstack.org> | 2012-11-24 02:44:33 +0000 |
|---|---|---|
| committer | Gerrit Code Review <review@openstack.org> | 2012-11-24 02:44:33 +0000 |
| commit | 62c832b9b363096f93f4512a7aed35668c4d6a87 (patch) | |
| tree | 519b1036e63d6263734ac2e1bc58ba60bc09ef8d | |
| parent | b4c0767e5529eb5d58aed90643354dbee83efefe (diff) | |
| parent | 68fe32580ea4f7058bb15821566fa8ff10876ec5 (diff) | |
| download | oslo-62c832b9b363096f93f4512a7aed35668c4d6a87.tar.gz oslo-62c832b9b363096f93f4512a7aed35668c4d6a87.tar.xz oslo-62c832b9b363096f93f4512a7aed35668c4d6a87.zip | |
Merge "raise_on_error parameter shouldn't be passed to task function"
| -rw-r--r-- | openstack/common/periodic_task.py | 5 | ||||
| -rw-r--r-- | tests/unit/test_periodic.py | 23 |
2 files changed, 11 insertions, 17 deletions
diff --git a/openstack/common/periodic_task.py b/openstack/common/periodic_task.py index edfee9b..8a32162 100644 --- a/openstack/common/periodic_task.py +++ b/openstack/common/periodic_task.py @@ -87,9 +87,8 @@ class _PeriodicTasksMeta(type): class PeriodicTasks(object): __metaclass__ = _PeriodicTasksMeta - def run_periodic_tasks(self, *args, **kwargs): + def run_periodic_tasks(self, context, raise_on_error=False): """Tasks to be run at a periodic interval.""" - raise_on_error = kwargs.get('raise_on_error', False) for task_name, task in self._periodic_tasks: full_task_name = '.'.join([self.__class__.__name__, task_name]) @@ -104,7 +103,7 @@ class PeriodicTasks(object): LOG.debug(_("Running periodic task %(full_task_name)s"), locals()) try: - task(self, *args, **kwargs) + task(self, context) except Exception as e: if raise_on_error: raise diff --git a/tests/unit/test_periodic.py b/tests/unit/test_periodic.py index fea83a2..c39d085 100644 --- a/tests/unit/test_periodic.py +++ b/tests/unit/test_periodic.py @@ -29,22 +29,17 @@ class AService(periodic_task.PeriodicTasks): self.called = {} @periodic_task.periodic_task - def doit(self, *args, **kwargs): + def doit(self, context): self.called['doit'] = True @periodic_task.periodic_task - def crashit(self, *args, **kwargs): + def crashit(self, context): + self.called['urg'] = True raise Exception('urg') - @periodic_task.periodic_task - def doit_with_kwargs(self, *args, **kwargs): - for n, v in kwargs.iteritems(): - self.called[n] = v - @periodic_task.periodic_task(ticks_between_runs=1) - def doit_with_kwargs_odd(self, *args, **kwargs): - for n, v in kwargs.iteritems(): - self.called[n] = v + def doit_with_kwargs_odd(self, context): + self.called['ticks'] = True class PeriodicTasksTestCase(utils.BaseTestCase): @@ -52,14 +47,14 @@ class PeriodicTasksTestCase(utils.BaseTestCase): def test_is_called(self): serv = AService() - serv.run_periodic_tasks(this='works') + serv.run_periodic_tasks(None) self.assertTrue(serv.called['doit']) self.assertTrue(len(serv.called) == 2) def test_called_twice(self): serv = AService() - serv.run_periodic_tasks(this='works') - serv.run_periodic_tasks(that='works') + serv.run_periodic_tasks(None) + serv.run_periodic_tasks(None) # expect doit_with_kwargs to be called twice # and doit_with_kwargs_odd to be called once. self.assertTrue(len(serv.called) == 3) @@ -68,4 +63,4 @@ class PeriodicTasksTestCase(utils.BaseTestCase): serv = AService() self.assertRaises(Exception, serv.run_periodic_tasks, - raise_on_error=True) + None, raise_on_error=True) |
