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

Side by Side Diff: git_cache.py

Issue 251413002: Python fallback for git cache bootstrap (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/tools/depot_tools
Patch Set: Created 6 years, 8 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 unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « no previous file | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 #!/usr/bin/env python 1 #!/usr/bin/env python
2 # Copyright 2014 The Chromium Authors. All rights reserved. 2 # Copyright 2014 The Chromium Authors. All rights reserved.
3 # Use of this source code is governed by a BSD-style license that can be 3 # Use of this source code is governed by a BSD-style license that can be
4 # found in the LICENSE file. 4 # found in the LICENSE file.
5 5
6 """A git command for managing a local cache of git repositories.""" 6 """A git command for managing a local cache of git repositories."""
7 7
8 from __future__ import print_function 8 from __future__ import print_function
9 import errno 9 import errno
10 import logging 10 import logging
11 import optparse 11 import optparse
12 import os 12 import os
13 import tempfile 13 import tempfile
14 import time 14 import time
15 import subprocess 15 import subprocess
16 import sys 16 import sys
17 import urlparse 17 import urlparse
18 import zipfile
18 19
19 from download_from_google_storage import Gsutil 20 from download_from_google_storage import Gsutil
20 import gclient_utils 21 import gclient_utils
21 import subcommand 22 import subcommand
22 23
23 try: 24 try:
24 # pylint: disable=E0602 25 # pylint: disable=E0602
25 WinErr = WindowsError 26 WinErr = WindowsError
26 except NameError: 27 except NameError:
27 class WinErr(Exception): 28 class WinErr(Exception):
(...skipping 187 matching lines...) Expand 10 before | Expand all | Expand 10 after
215 '+refs/heads/*:refs/heads/*'], cwd=cwd) 216 '+refs/heads/*:refs/heads/*'], cwd=cwd)
216 for ref in self.refs: 217 for ref in self.refs:
217 ref = ref.lstrip('+').rstrip('/') 218 ref = ref.lstrip('+').rstrip('/')
218 if ref.startswith('refs/'): 219 if ref.startswith('refs/'):
219 refspec = '+%s:%s' % (ref, ref) 220 refspec = '+%s:%s' % (ref, ref)
220 else: 221 else:
221 refspec = '+refs/%s/*:refs/%s/*' % (ref, ref) 222 refspec = '+refs/%s/*:refs/%s/*' % (ref, ref)
222 self.RunGit(['config', '--add', 'remote.origin.fetch', refspec], cwd=cwd) 223 self.RunGit(['config', '--add', 'remote.origin.fetch', refspec], cwd=cwd)
223 224
224 def bootstrap_repo(self, directory): 225 def bootstrap_repo(self, directory):
225 """Bootstrap the repo from Google Stroage if possible. 226 """Bootstrap the repo from Google Stroage if possible."""
226 227
227 Requires 7z on Windows and Unzip on Linux/Mac. 228 python_fallback = False
228 """
229 if sys.platform.startswith('win'): 229 if sys.platform.startswith('win'):
agable 2014/04/25 05:41:39 sys.platform.... and not self.FindExec...
Ryan Tseng 2014/04/25 08:49:47 Done.
230 if not self.FindExecutable('7z'): 230 if not self.FindExecutable('7z'):
231 self.print(''' 231 python_fallback = True
232 Cannot find 7z in the path. If you want git cache to be able to bootstrap from 232 elif sys.platform.startswith('darwin'):
233 Google Storage, please install 7z from: 233 # The OSX version of unzip doesn't support zip64.
234 234 python_fallback = True
235 http://www.7-zip.org/download.html 235 elif not self.FindExecutable('unzip'):
236 ''') 236 python_fallback = True
237 return False
238 else:
239 if not self.FindExecutable('unzip'):
240 self.print('''
241 Cannot find unzip in the path. If you want git cache to be able to bootstrap
242 from Google Storage, please ensure unzip is present on your system.
243 ''')
244 return False
245 237
246 gs_folder = 'gs://%s/%s' % (self.bootstrap_bucket, self.basedir) 238 gs_folder = 'gs://%s/%s' % (self.bootstrap_bucket, self.basedir)
247 gsutil = Gsutil( 239 gsutil = Gsutil(
248 self.gsutil_exe, boto_path=os.devnull, bypass_prodaccess=True) 240 self.gsutil_exe, boto_path=os.devnull, bypass_prodaccess=True)
249 # Get the most recent version of the zipfile. 241 # Get the most recent version of the zipfile.
250 _, ls_out, _ = gsutil.check_call('ls', gs_folder) 242 _, ls_out, _ = gsutil.check_call('ls', gs_folder)
251 ls_out_sorted = sorted(ls_out.splitlines()) 243 ls_out_sorted = sorted(ls_out.splitlines())
252 if not ls_out_sorted: 244 if not ls_out_sorted:
253 # This repo is not on Google Storage. 245 # This repo is not on Google Storage.
254 return False 246 return False
255 latest_checkout = ls_out_sorted[-1] 247 latest_checkout = ls_out_sorted[-1]
256 248
257 # Download zip file to a temporary directory. 249 # Download zip file to a temporary directory.
258 try: 250 try:
259 tempdir = tempfile.mkdtemp() 251 tempdir = tempfile.mkdtemp()
260 self.print('Downloading %s' % latest_checkout) 252 self.print('Downloading %s' % latest_checkout)
261 code, out, err = gsutil.check_call('cp', latest_checkout, tempdir) 253 code, out, err = gsutil.check_call('cp', latest_checkout, tempdir)
262 if code: 254 if code:
263 self.print('%s\n%s' % (out, err)) 255 self.print('%s\n%s' % (out, err))
264 return False 256 return False
265 filename = os.path.join(tempdir, latest_checkout.split('/')[-1]) 257 filename = os.path.join(tempdir, latest_checkout.split('/')[-1])
266 258
267 # Unpack the file with 7z on Windows, or unzip everywhere else. 259 # Unpack the file with 7z on Windows, unzip on linux, or fallback.
268 if sys.platform.startswith('win'): 260 if python_fallback:
agable 2014/04/25 05:41:39 Flop these. Start with "if not python_fallback:"..
Ryan Tseng 2014/04/25 08:49:47 Done.
269 cmd = ['7z', 'x', '-o%s' % directory, '-tzip', filename] 261 try:
262 with zipfile.ZipFile(filename, 'r') as f:
263 f.printdir()
agable 2014/04/25 05:41:39 Is this necessary or is it debugging?
Ryan Tseng 2014/04/25 08:49:47 Its not, but its there to match the behavior of 7z
264 f.extractall(directory)
265 except Exception as e:
266 self.print('Encountered error: %s' % str(e), file=sys.stderr)
267 retcode = 1
268 else:
269 retcode = 0
270 else: 270 else:
271 cmd = ['unzip', filename, '-d', directory] 271 if sys.platform.startswith('win'):
272 retcode = subprocess.call(cmd) 272 cmd = ['7z', 'x', '-o%s' % directory, '-tzip', filename]
273 else:
274 cmd = ['unzip', filename, '-d', directory]
275 retcode = subprocess.call(cmd)
273 finally: 276 finally:
274 # Clean up the downloaded zipfile. 277 # Clean up the downloaded zipfile.
275 gclient_utils.rmtree(tempdir) 278 gclient_utils.rmtree(tempdir)
276 279
277 if retcode: 280 if retcode:
278 self.print( 281 self.print(
279 'Extracting bootstrap zipfile %s failed.\n' 282 'Extracting bootstrap zipfile %s failed.\n'
280 'Resuming normal operations.' % filename) 283 'Resuming normal operations.' % filename)
281 return False 284 return False
282 return True 285 return True
(...skipping 222 matching lines...) Expand 10 before | Expand all | Expand 10 after
505 return options, args 508 return options, args
506 509
507 510
508 def main(argv): 511 def main(argv):
509 dispatcher = subcommand.CommandDispatcher(__name__) 512 dispatcher = subcommand.CommandDispatcher(__name__)
510 return dispatcher.execute(OptionParser(), argv) 513 return dispatcher.execute(OptionParser(), argv)
511 514
512 515
513 if __name__ == '__main__': 516 if __name__ == '__main__':
514 sys.exit(main(sys.argv[1:])) 517 sys.exit(main(sys.argv[1:]))
OLDNEW
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698