| 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
|
| index 5d386ebba205ed1d7b7c3e787651d9209ba9f7ef..795e62f35b56c34aae9b1c1dcb124db3a7aca264 100644
|
| --- a/chrome/common/extensions/docs/server2/branch_utility.py
|
| +++ b/chrome/common/extensions/docs/server2/branch_utility.py
|
| @@ -3,54 +3,47 @@
|
| # found in the LICENSE file.
|
|
|
| import logging
|
| -import re
|
| import json
|
|
|
| -class BranchUtility(object):
|
| - """Utility class for dealing with different doc branches.
|
| +OMAHA_PROXY_URL = 'http://omahaproxy.appspot.com/json'
|
| +
|
| +def GetChannelNameFromPath(path):
|
| + first_part = path.split('/')[0]
|
| + if first_part in ['trunk', 'dev', 'beta', 'stable', 'local']:
|
| + return first_part
|
| + else:
|
| + return 'stable'
|
| +
|
| +def GetBranchNumberForChannelName(channel_name,
|
| + urlfetch,
|
| + base_path=OMAHA_PROXY_URL):
|
| + """Returns an empty string if the branch number cannot be found.
|
| + Throws exception on network errors.
|
| """
|
| - def __init__(self, urlfetch):
|
| - self.omaha_proxy_url = 'http://omahaproxy.appspot.com/json'
|
| - self.urlfetch = urlfetch
|
| -
|
| - def SetURL(self, url):
|
| - self.omaha_proxy_url = url
|
| -
|
| - def GetChannelNameFromPath(self, path):
|
| - first_part = path.split('/')[0]
|
| - if first_part in ['trunk', 'dev', 'beta', 'stable', 'local']:
|
| - return first_part
|
| - else:
|
| - return 'stable'
|
| -
|
| - def GetBranchNumberForChannelName(self, channel_name):
|
| - """Returns an empty string if the branch number cannot be found.
|
| - Throws exception on network errors.
|
| - """
|
| - if channel_name == 'trunk' or channel_name == 'local':
|
| - return channel_name
|
| -
|
| - fetch_data = self.urlfetch.fetch(self.omaha_proxy_url)
|
| - if fetch_data.content == '':
|
| - raise Exception('Fetch returned zero results.')
|
| -
|
| - version_json = json.loads(fetch_data.content)
|
| - branch_numbers = {}
|
| - for entry in version_json:
|
| - if entry['os'] not in ['win', 'linux', 'mac', 'cros']:
|
| + if channel_name == 'trunk' or channel_name == 'local':
|
| + return channel_name
|
| +
|
| + fetch_data = urlfetch.fetch(base_path)
|
| + if fetch_data.content == '':
|
| + raise Exception('Fetch returned zero results.')
|
| +
|
| + version_json = json.loads(fetch_data.content)
|
| + branch_numbers = {}
|
| + for entry in version_json:
|
| + if entry['os'] not in ['win', 'linux', 'mac', 'cros']:
|
| + continue
|
| + for version in entry['versions']:
|
| + if version['channel'] != channel_name:
|
| 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
|
| + 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()
|
| + sorted_list = [x for x in branch_numbers.iteritems()]
|
| + sorted_list.sort(key = lambda x: x[1])
|
| + sorted_list.reverse()
|
|
|
| - branch_number, _ = sorted_list[0]
|
| + branch_number, _ = sorted_list[0]
|
|
|
| - return branch_number
|
| + return branch_number
|
|
|