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

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

Issue 10387225: Die build.py, Die: Part 1 (BranchUtility and SubversionFetcher) (Closed) Base URL: http://git.chromium.org/chromium/src.git@master
Patch Set: Unit tests Created 8 years, 7 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/branch_utility.py
diff --git a/chrome/common/extensions/docs/server2/branch_utility.py b/chrome/common/extensions/docs/server2/branch_utility.py
new file mode 100644
index 0000000000000000000000000000000000000000..9051e49da4bf437f583620a90e0de07c9aa231be
--- /dev/null
+++ b/chrome/common/extensions/docs/server2/branch_utility.py
@@ -0,0 +1,70 @@
+# Copyright (c) 2012 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.
+
+import logging
+import re
+import json
+
+from memcache import MemcacheAdd, MemcacheGet
+from fetch import Fetch
+
+class BranchUtility(object):
+ """Utility class for dealing with different doc branches.
+ """
+ def __init__(self):
Aaron Boodman 2012/05/22 22:45:02 You could simplify this somewhat by passing the ur
cduvall 2012/05/24 00:15:40 Done.
+ self.url = 'http://omahaproxy.appspot.com/json'
+
+ def SetURL(self, url):
+ self.url = url
+
+ def _FetchURL(self, url):
+ return Fetch(url)
+
+ def GetChannelNameFromURL(self, url):
Aaron Boodman 2012/05/22 22:45:02 I guess it's really GetChannelNameFromPath(), righ
cduvall 2012/05/24 00:15:40 Done.
+ if url.startswith('dev'):
Aaron Boodman 2012/05/22 22:45:02 startswith('dev/') ... same for the other branches
Aaron Boodman 2012/05/22 22:45:02 first_part = path.split('/')[0] if first_part in [
cduvall 2012/05/24 00:15:40 Done.
+ return 'dev'
+ if url.startswith('beta'):
+ return 'beta'
+ if url.startswith('trunk'):
+ return 'trunk'
+ return 'stable'
+
+ def GetBranchNumberForURL(self, url):
+ """Returns an empty string if the branch number cannot be found.
+ """
+ channel_name = self.GetChannelNameFromURL(url)
+ if channel_name == 'trunk':
+ return 'trunk'
Aaron Boodman 2012/05/22 22:45:02 Still seems weird to accept trunk as an argument,
cduvall 2012/05/24 00:15:40 I don't really like accepting trunk paths as an ar
+
+ result = MemcacheGet(url, 'urls')
Aaron Boodman 2012/05/22 22:45:02 With my change above, you wouldn't need this memca
cduvall 2012/05/24 00:15:40 Done.
+ if result is not None:
+ return result
+ logging.info('Branch number cache miss: ' + url)
+ fetch_data = self._FetchURL(self.url)
+
+ version_json = json.loads(fetch_data)
+ branch_numbers = {}
+ for entry in version_json:
+ if entry['os'] == 'cf':
Aaron Boodman 2012/05/22 22:45:02 On second thought, let's be more robust and have a
cduvall 2012/05/24 00:15:40 Done.
+ continue
+ for version in entry['versions']:
+ if version['channel'] != channel_name:
+ continue
+ if version['true_branch'] not in branch_numbers:
+ branch_numbers[version['true_branch']] = 0
+ else:
+ branch_numbers[version['true_branch']] += 1
+
+ sorted_list = [x for x in branch_numbers.iteritems()]
+ sorted_list.sort(key = lambda x: x[1])
+ sorted_list.reverse()
+
+ branch_number = ''
+ if len(sorted_list) > 0:
+ branch_number, _ = sorted_list[0]
+
+ if not MemcacheAdd(url, branch_number, 'urls'):
+ logging.error('Memcache set failed.')
+
+ return branch_number

Powered by Google App Engine
This is Rietveld 408576698