Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(699)

Side by Side Diff: chrome/common/extensions/docs/server2/refresh_tracker.py

Issue 660383002: Docserver: Persist stat cache for versioned file systems (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 6 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(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))
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698