Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 # Copyright 2014 The Chromium Authors. All rights reserved. | |
| 2 # Use of this source code is governed by a BSD-style license that can be | |
| 3 # found in the LICENSE file. | |
| 4 | |
| 5 from future import Future | |
| 6 | |
| 7 | |
| 8 class _RefreshWorkOrder(object): | |
| 9 '''A set of tasks that must be completed in a refresh cycle.''' | |
| 10 def __init__(self, tasks): | |
| 11 self.tasks = set(tasks) | |
| 12 | |
| 13 | |
| 14 def _RefreshTaskCompletion(object): | |
| 15 '''Marks the completion of a single named task for some refresh cycle.''' | |
| 16 def __init__(self, task): | |
| 17 self.task = task | |
| 18 | |
| 19 | |
| 20 def _GetTaskCompletionKey(refresh_id, task): | |
| 21 return '%s@%s' % (refresh_id, task) | |
| 22 | |
| 23 | |
| 24 class RefreshTracker(object): | |
|
not at google - send to devlin
2014/10/22 18:08:48
Tests for this class?
Ken Rockot(use gerrit already)
2014/10/23 22:36:16
Done.
| |
| 25 '''Manages and tracks the progress of data refresh cycles.''' | |
| 26 def __init__(self, object_store_creator): | |
| 27 self._work_orders = object_store_creator.Create(_RefreshWorkOrder, | |
| 28 category='refresh_work_orders') | |
| 29 self._task_completions = object_store_creator.Create(_RefreshTaskCompletion, | |
| 30 category='refresh_task_completions') | |
| 31 | |
| 32 def _GetWorkOrder(self, refresh_id): | |
| 33 '''Retrieves the work order for a refresh cycle identified by |id|.''' | |
| 34 return self._work_orders.Get(refresh_id) | |
| 35 | |
| 36 def _GetTaskCompletion(self, refresh_id, task): | |
| 37 '''Retrieves the set of task completions for a refresh cycle identified by | |
| 38 |id|.''' | |
| 39 return self._task_completions.Get(_GetTaskCompletionKey(refresh_id, task)) | |
| 40 | |
| 41 def RegisterRefresh(self, refresh_id, tasks): | |
| 42 work_order = _RefreshWorkOrder(tasks) | |
| 43 return self._work_orders.Set(refresh_id, work_order) | |
| 44 | |
| 45 def GetRefreshComplete(self, refresh_id): | |
| 46 '''Determines if a refresh cycle identified by |id| is complete. Returns | |
| 47 a |Future| which resolves to either |True| or |False|.''' | |
| 48 def is_work_order_complete(work_order): | |
| 49 # If the identified refresh cycle is not known, always return False. | |
| 50 if work_order is None: | |
| 51 return False | |
| 52 | |
| 53 futures = [self._GetTaskCompletion(refresh_id, task) | |
| 54 for task in work_order.tasks] | |
| 55 return All(futures).Then(callback=lambda results: None not in results) | |
| 56 | |
| 57 return self._GetWorkOrder(refresh_id).Then(is_work_order_complete) | |
| 58 | |
| 59 def MarkTaskComplete(self, refresh_id, task): | |
| 60 return self._task_completions.Set(_GetTaskCompletionKey(refresh_id, task), | |
| 61 _RefreshTaskCompletion(task)) | |
| OLD | NEW |