Commit b0a13a2a authored by szager@chromium.org's avatar szager@chromium.org

Refactor cache-updating code to eliminate unnecessary fetches.

This is an update of the following reverted change:

https://codereview.chromium.org/344443002/

R=hinoka@chromium.org,agable@chromium.org
BUG=

Review URL: https://codereview.chromium.org/343523002

git-svn-id: svn://svn.chromium.org/chrome/trunk/tools/depot_tools@277931 0039d316-1c4b-4281-b951-d872f2087c98
parent 1cbf1048
...@@ -356,8 +356,6 @@ class GitWrapper(SCMWrapper): ...@@ -356,8 +356,6 @@ class GitWrapper(SCMWrapper):
verbose = ['--verbose'] verbose = ['--verbose']
printed_path = True printed_path = True
url = self._CreateOrUpdateCache(url, options)
if revision.startswith('refs/'): if revision.startswith('refs/'):
rev_type = "branch" rev_type = "branch"
elif revision.startswith(self.remote + '/'): elif revision.startswith(self.remote + '/'):
...@@ -368,9 +366,15 @@ class GitWrapper(SCMWrapper): ...@@ -368,9 +366,15 @@ class GitWrapper(SCMWrapper):
# hash is also a tag, only make a distinction at checkout # hash is also a tag, only make a distinction at checkout
rev_type = "hash" rev_type = "hash"
mirror = self._GetMirror(url, options)
if mirror:
url = mirror.mirror_path
if (not os.path.exists(self.checkout_path) or if (not os.path.exists(self.checkout_path) or
(os.path.isdir(self.checkout_path) and (os.path.isdir(self.checkout_path) and
not os.path.exists(os.path.join(self.checkout_path, '.git')))): not os.path.exists(os.path.join(self.checkout_path, '.git')))):
if mirror:
self._UpdateMirror(mirror, options)
try: try:
self._Clone(revision, url, options) self._Clone(revision, url, options)
except subprocess2.CalledProcessError: except subprocess2.CalledProcessError:
...@@ -394,6 +398,9 @@ class GitWrapper(SCMWrapper): ...@@ -394,6 +398,9 @@ class GitWrapper(SCMWrapper):
self.Print('________ unmanaged solution; skipping %s' % self.relpath) self.Print('________ unmanaged solution; skipping %s' % self.relpath)
return self._Capture(['rev-parse', '--verify', 'HEAD']) return self._Capture(['rev-parse', '--verify', 'HEAD'])
if mirror:
self._UpdateMirror(mirror, options)
# See if the url has changed (the unittests use git://foo for the url, let # See if the url has changed (the unittests use git://foo for the url, let
# that through). # that through).
current_url = self._Capture(['config', 'remote.%s.url' % self.remote]) current_url = self._Capture(['config', 'remote.%s.url' % self.remote])
...@@ -745,14 +752,10 @@ class GitWrapper(SCMWrapper): ...@@ -745,14 +752,10 @@ class GitWrapper(SCMWrapper):
base_url = self.url base_url = self.url
return base_url[:base_url.rfind('/')] + url return base_url[:base_url.rfind('/')] + url
def _CreateOrUpdateCache(self, url, options): def _GetMirror(self, url, options):
"""Make a new git mirror or update existing mirror for |url|, and return the """Get a git_cache.Mirror object for the argument url."""
mirror URI to clone from. if not git_cache.Mirror.GetCachePath():
return None
If no cache-dir is specified, just return |url| unchanged.
"""
if not self.cache_dir:
return url
mirror_kwargs = { mirror_kwargs = {
'print_func': self.filter, 'print_func': self.filter,
'refs': [] 'refs': []
...@@ -765,10 +768,14 @@ class GitWrapper(SCMWrapper): ...@@ -765,10 +768,14 @@ class GitWrapper(SCMWrapper):
# mirror_kwargs['refs'].extend(['refs/tags/lkgr', 'refs/tags/lkcr']) # mirror_kwargs['refs'].extend(['refs/tags/lkgr', 'refs/tags/lkcr'])
if hasattr(options, 'with_branch_heads') and options.with_branch_heads: if hasattr(options, 'with_branch_heads') and options.with_branch_heads:
mirror_kwargs['refs'].append('refs/branch-heads/*') mirror_kwargs['refs'].append('refs/branch-heads/*')
mirror = git_cache.Mirror(url, **mirror_kwargs) return git_cache.Mirror(url, **mirror_kwargs)
@staticmethod
def _UpdateMirror(mirror, options):
"""Update a git mirror by fetching the latest commits from the remote."""
if options.shallow: if options.shallow:
# HACK(hinoka): These repositories should be super shallow. # HACK(hinoka): These repositories should be super shallow.
if 'flash' in url: if 'flash' in mirror.url:
depth = 10 depth = 10
else: else:
depth = 10000 depth = 10000
...@@ -776,7 +783,6 @@ class GitWrapper(SCMWrapper): ...@@ -776,7 +783,6 @@ class GitWrapper(SCMWrapper):
depth = None depth = None
mirror.populate(verbose=options.verbose, bootstrap=True, depth=depth) mirror.populate(verbose=options.verbose, bootstrap=True, depth=depth)
mirror.unlock() mirror.unlock()
return mirror.mirror_path if mirror.exists() else None
def _Clone(self, revision, url, options): def _Clone(self, revision, url, options):
"""Clone a git repository from the given URL. """Clone a git repository from the given URL.
......
...@@ -318,6 +318,7 @@ class Mirror(object): ...@@ -318,6 +318,7 @@ class Mirror(object):
def populate(self, depth=None, shallow=False, bootstrap=False, def populate(self, depth=None, shallow=False, bootstrap=False,
verbose=False): verbose=False):
assert self.GetCachePath()
if shallow and not depth: if shallow and not depth:
depth = 10000 depth = 10000
gclient_utils.safe_makedirs(self.GetCachePath()) gclient_utils.safe_makedirs(self.GetCachePath())
...@@ -429,6 +430,8 @@ class Mirror(object): ...@@ -429,6 +430,8 @@ class Mirror(object):
@classmethod @classmethod
def UnlockAll(cls): def UnlockAll(cls):
cachepath = cls.GetCachePath() cachepath = cls.GetCachePath()
if not cachepath:
return
dirlist = os.listdir(cachepath) dirlist = os.listdir(cachepath)
repo_dirs = set([os.path.join(cachepath, path) for path in dirlist repo_dirs = set([os.path.join(cachepath, path) for path in dirlist
if os.path.isdir(os.path.join(cachepath, path))]) if os.path.isdir(os.path.join(cachepath, path))])
......
...@@ -24,8 +24,12 @@ from testing_support.super_mox import mox, StdoutCheck, SuperMoxTestBase ...@@ -24,8 +24,12 @@ from testing_support.super_mox import mox, StdoutCheck, SuperMoxTestBase
from testing_support.super_mox import TestCaseUtils from testing_support.super_mox import TestCaseUtils
import gclient_scm import gclient_scm
import git_cache
import subprocess2 import subprocess2
# Disable global git cache
git_cache.Mirror.SetCachePath(None)
# Shortcut since this function is used often # Shortcut since this function is used often
join = gclient_scm.os.path.join join = gclient_scm.os.path.join
...@@ -1571,11 +1575,11 @@ class UnmanagedGitWrapperTestCase(BaseGitWrapperTestCase): ...@@ -1571,11 +1575,11 @@ class UnmanagedGitWrapperTestCase(BaseGitWrapperTestCase):
if __name__ == '__main__': if __name__ == '__main__':
if '-v' in sys.argv: level = logging.DEBUG if '-v' in sys.argv else logging.FATAL
logging.basicConfig( logging.basicConfig(
level=logging.DEBUG, level=level,
format='%(asctime).19s %(levelname)s %(filename)s:' format='%(asctime).19s %(levelname)s %(filename)s:'
'%(lineno)s %(message)s') '%(lineno)s %(message)s')
unittest.main() unittest.main()
# vim: ts=2:sw=2:tw=80:et: # vim: ts=2:sw=2:tw=80:et:
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment