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

Unified Diff: chrome/common/extensions/docs/server2/refresh_tracker.py

Issue 1151283007: Docserver overhaul: Gitiles away from me. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Remove inform_users template to fix presubmit failure (it's now a redirect) Created 5 years, 6 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 side-by-side diff with in-line comments
Download patch
Index: chrome/common/extensions/docs/server2/refresh_tracker.py
diff --git a/chrome/common/extensions/docs/server2/refresh_tracker.py b/chrome/common/extensions/docs/server2/refresh_tracker.py
deleted file mode 100644
index e71444812daa5e470644760704e4f76aade3eaa0..0000000000000000000000000000000000000000
--- a/chrome/common/extensions/docs/server2/refresh_tracker.py
+++ /dev/null
@@ -1,56 +0,0 @@
-# Copyright 2014 The Chromium Authors. All rights reserved.
-# Use of this source code is governed by a BSD-style license that can be
-# found in the LICENSE file.
-
-from future import All, Future
-
-
-class _RefreshWorkOrder(object):
- '''A set of tasks that must be completed in a refresh cycle.'''
- def __init__(self, tasks):
- self.tasks = set(tasks)
-
-
-class _RefreshTaskCompletion(object):
- '''Marks the completion of a single named task for some refresh cycle.'''
- def __init__(self, task):
- self.task = task
-
-
-def _TaskKey(refresh_id, task):
- return '%s@%s' % (refresh_id, task)
-
-
-class RefreshTracker(object):
- '''Manages and tracks the progress of data refresh cycles.'''
- def __init__(self, object_store_creator):
- # These object stores should never be created empty since they are strictly
- # used to persist state across requests.
- self._work_orders = object_store_creator.Create(_RefreshWorkOrder,
- start_empty=False)
- self._task_completions = object_store_creator.Create(_RefreshTaskCompletion,
- start_empty=False)
-
- def _GetWorkOrder(self, refresh_id):
- '''Retrieves the work order for a refresh cycle identified by |id|.'''
- return self._work_orders.Get(refresh_id)
-
- def StartRefresh(self, refresh_id, tasks):
- work_order = _RefreshWorkOrder(tasks)
- return self._work_orders.Set(refresh_id, work_order)
-
- def GetRefreshComplete(self, refresh_id):
- '''Determines if a refresh cycle identified by |id| is complete. Returns
- a |Future| which resolves to either |True| or |False|.'''
- def is_work_order_complete(work_order):
- # If the identified refresh cycle is not known, always return False.
- if work_order is None:
- return False
- return (self._task_completions.GetMulti(
- _TaskKey(refresh_id, task) for task in work_order.tasks)
- .Then(lambda tasks: len(tasks) == len(work_order.tasks)))
- return self._GetWorkOrder(refresh_id).Then(is_work_order_complete)
-
- def MarkTaskComplete(self, refresh_id, task):
- return self._task_completions.Set(_TaskKey(refresh_id, task),
- _RefreshTaskCompletion(task))

Powered by Google App Engine
This is Rietveld 408576698