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 All, 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 class _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): | |
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', start_empty=False) | |
29 self._task_completions = object_store_creator.Create(_RefreshTaskCompletion, | |
30 category='refresh_task_completions', start_empty=False) | |
not at google - send to devlin
2014/10/24 00:04:52
It seems like you're double-namespacing these thin
Ken Rockot(use gerrit already)
2014/10/24 21:26:54
As noted on CommitTracker, yeah, I was using this
| |
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 RegisterRefresh(self, refresh_id, tasks): | |
37 work_order = _RefreshWorkOrder(tasks) | |
38 return self._work_orders.Set(refresh_id, work_order) | |
39 | |
40 def GetRefreshComplete(self, refresh_id): | |
41 '''Determines if a refresh cycle identified by |id| is complete. Returns | |
42 a |Future| which resolves to either |True| or |False|.''' | |
43 def is_work_order_complete(work_order): | |
44 # If the identified refresh cycle is not known, always return False. | |
45 if work_order is None: | |
46 return False | |
47 future = self._task_completions.GetMulti( | |
48 _GetTaskCompletionKey(refresh_id, task) for task in work_order.tasks) | |
49 return len(future.Get()) == len(work_order.tasks) | |
not at google - send to devlin
2014/10/24 00:04:52
Can you turn this .Get() into a .Then()?
Ken Rockot(use gerrit already)
2014/10/24 21:26:54
Done.
| |
50 | |
51 return self._GetWorkOrder(refresh_id).Then(is_work_order_complete) | |
52 | |
53 def MarkTaskComplete(self, refresh_id, task): | |
54 return self._task_completions.Set(_GetTaskCompletionKey(refresh_id, task), | |
55 _RefreshTaskCompletion(task)) | |
OLD | NEW |