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

Unified Diff: tools/perf/core/bootstrap.py

Issue 2933163002: Revert of Remove find_dependencies script (Closed)
Patch Set: Created 3 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
« no previous file with comments | « no previous file | tools/perf/core/find_dependencies.py » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: tools/perf/core/bootstrap.py
diff --git a/tools/perf/core/bootstrap.py b/tools/perf/core/bootstrap.py
new file mode 100644
index 0000000000000000000000000000000000000000..3a25f5f053c9bc73cde6fb4065f9fa45e3d1b636
--- /dev/null
+++ b/tools/perf/core/bootstrap.py
@@ -0,0 +1,161 @@
+# 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.
+
+"""Bootstrap Chrome Telemetry by downloading all its files from SVN servers.
+
+Requires a DEPS file to specify which directories on which SVN servers
+are required to run Telemetry. Format of that DEPS file is a subset of the
+normal DEPS file format[1]; currently only only the "deps" dictionary is
+supported and nothing else.
+
+Fetches all files in the specified directories using WebDAV (SVN is WebDAV under
+the hood).
+
+[1] http://dev.chromium.org/developers/how-tos/depottools#TOC-DEPS-file
+"""
+
+import imp
+import logging
+import os
+import urllib
+import urlparse
+
+# Dummy module for DAVclient.
+davclient = None
+
+
+# TODO(eakuefner): Switch this link to tools/perf version after verifying.
+# Link to file containing the 'davclient' WebDAV client library.
+_DAVCLIENT_URL = ('https://src.chromium.org/chrome/trunk/src/tools/'
+ 'telemetry/third_party/davclient/davclient.py')
+
+
+def _DownloadAndImportDAVClientModule():
+ """Dynamically import davclient helper library."""
+ global davclient
+ davclient_src = urllib.urlopen(_DAVCLIENT_URL).read()
+ davclient = imp.new_module('davclient')
+ exec davclient_src in davclient.__dict__ # pylint: disable=exec-used
+
+
+class DAVClientWrapper(object):
+ """Knows how to retrieve subdirectories and files from WebDAV/SVN servers."""
+
+ def __init__(self, root_url):
+ """Initialize SVN server root_url, save files to local dest_dir.
+
+ Args:
+ root_url: string url of SVN/WebDAV server
+ """
+ self.root_url = root_url
+ self.client = davclient.DAVClient(root_url)
+
+ @staticmethod
+ def __norm_path_keys(dict_with_path_keys):
+ """Returns a dictionary with os.path.normpath called on every key."""
+ return dict((os.path.normpath(k), v) for (k, v) in
+ dict_with_path_keys.items())
+
+ def GetDirList(self, path):
+ """Returns string names of all files and subdirs of path on the server."""
+ props = self.__norm_path_keys(self.client.propfind(path, depth=1))
+ # remove this path
+ del props[os.path.normpath(path)]
+ return [os.path.basename(p) for p in props.keys()]
+
+ def IsFile(self, path):
+ """Returns True if the path is a file on the server, False if directory."""
+ props = self.__norm_path_keys(self.client.propfind(path, depth=1))
+ return props[os.path.normpath(path)]['resourcetype'] is None
+
+ def Traverse(self, src_path, dst_path):
+ """Walks the directory hierarchy pointed to by src_path download all files.
+
+ Recursively walks src_path and saves all files and subfolders into
+ dst_path.
+
+ Args:
+ src_path: string path on SVN server to save (absolute path on server).
+ dest_path: string local path (relative or absolute) to save to.
+ """
+ if self.IsFile(src_path):
+ if not os.path.exists(os.path.dirname(dst_path)):
+ logging.info('Creating %s', os.path.dirname(dst_path))
+ os.makedirs(os.path.dirname(dst_path))
+ if os.path.isfile(dst_path):
+ logging.info('Skipping %s', dst_path)
+ else:
+ logging.info('Saving %s to %s', self.root_url + src_path, dst_path)
+ urllib.urlretrieve(self.root_url + src_path, dst_path)
+ return
+ else:
+ for subdir in self.GetDirList(src_path):
+ self.Traverse(os.path.join(src_path, subdir),
+ os.path.join(dst_path, subdir))
+
+
+def ListAllDepsPaths(deps_file):
+ """Recursively returns a list of all paths indicated in this deps file.
+
+ Note that this discards information about where path dependencies come from,
+ so this is only useful in the context of a Chromium source checkout that has
+ already fetched all dependencies.
+
+ Args:
+ deps_file: File containing deps information to be evaluated, in the
+ format given in the header of this file.
+ Returns:
+ A list of string paths starting under src that are required by the
+ given deps file, and all of its sub-dependencies. This amounts to
+ the keys of the 'deps' dictionary.
+ """
+ deps = {}
+ deps_includes = {}
+
+ chrome_root = os.path.dirname(__file__)
+ while os.path.basename(chrome_root) != 'src':
+ chrome_root = os.path.abspath(os.path.join(chrome_root, '..'))
+
+ exec open(deps_file).read() # pylint: disable=exec-used
+
+ deps_paths = deps.keys()
+
+ for path in deps_includes.keys():
+ # Need to localize the paths.
+ path = os.path.join(chrome_root, '..', path)
+ deps_paths += ListAllDepsPaths(path)
+
+ return deps_paths
+
+
+def DownloadDeps(destination_dir, url):
+ """Saves all the dependencies in deps_path.
+
+ Opens and reads url, assuming the contents are in the simple DEPS-like file
+ format specified in the header of this file, then download all
+ files/directories listed to the destination_dir.
+
+ Args:
+ destination_dir: String path to directory to download files into.
+ url: URL containing deps information to be evaluated.
+ """
+ logging.warning('Downloading deps from %s...', url)
+ # TODO(wiltzius): Add a parameter for which revision to pull.
+ _DownloadAndImportDAVClientModule()
+
+ deps = {}
+ deps_includes = {}
+
+ exec urllib.urlopen(url).read() # pylint: disable=exec-used
+
+ for dst_path, src_path in deps.iteritems():
+ full_dst_path = os.path.join(destination_dir, dst_path)
+ parsed_url = urlparse.urlparse(src_path)
+ root_url = parsed_url.scheme + '://' + parsed_url.netloc
+
+ dav_client = DAVClientWrapper(root_url)
+ dav_client.Traverse(parsed_url.path, full_dst_path)
+
+ for url in deps_includes.values():
+ DownloadDeps(destination_dir, url)
« no previous file with comments | « no previous file | tools/perf/core/find_dependencies.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698