kjellander@webrtc.org | 8925662 | 2014-08-20 12:10:11 +0000 | [diff] [blame] | 1 | #!/usr/bin/env python |
| 2 | # Copyright (c) 2014 The WebRTC project authors. All Rights Reserved. |
| 3 | # |
| 4 | # Use of this source code is governed by a BSD-style license |
| 5 | # that can be found in the LICENSE file in the root of the source |
| 6 | # tree. An additional intellectual property rights grant can be found |
| 7 | # in the file PATENTS. All contributing project authors may |
| 8 | # be found in the AUTHORS file in the root of the source tree. |
| 9 | |
kjellander@webrtc.org | 8539bd0 | 2014-10-23 12:17:58 +0000 | [diff] [blame] | 10 | """Script to download a Chromium checkout into the workspace. |
| 11 | |
| 12 | The script downloads a full Chromium Git clone and its DEPS. |
| 13 | |
| 14 | The following environment variable can be used to alter the behavior: |
| 15 | * CHROMIUM_NO_HISTORY - If set to 1, a Git checkout with no history will be |
| 16 | downloaded. This is consumes less bandwidth and disk space but is known to be |
| 17 | slower in general if you have a high-speed connection. |
| 18 | |
| 19 | After a successful sync has completed, a .last_sync_chromium file is written to |
| 20 | the chromium directory. While it exists, no more gclient sync operations will be |
| 21 | performed until the --target-revision changes or the SCRIPT_VERSION constant is |
| 22 | incremented. The file can be removed manually to force a new sync. |
| 23 | """ |
| 24 | |
kjellander@webrtc.org | 8925662 | 2014-08-20 12:10:11 +0000 | [diff] [blame] | 25 | import argparse |
| 26 | import os |
| 27 | import subprocess |
| 28 | import sys |
kjellander@webrtc.org | 7430433 | 2015-03-05 14:38:09 +0000 | [diff] [blame] | 29 | import textwrap |
kjellander@webrtc.org | 8925662 | 2014-08-20 12:10:11 +0000 | [diff] [blame] | 30 | |
iannucci@chromium.org | 1613638 | 2014-08-21 15:48:23 +0000 | [diff] [blame] | 31 | # Bump this whenever the algorithm changes and you need bots/devs to re-sync, |
| 32 | # ignoring the .last_sync_chromium file |
kjellander@webrtc.org | bfdee69 | 2015-02-03 15:23:34 +0000 | [diff] [blame] | 33 | SCRIPT_VERSION = 4 |
kjellander@webrtc.org | 8925662 | 2014-08-20 12:10:11 +0000 | [diff] [blame] | 34 | |
| 35 | ROOT_DIR = os.path.dirname(os.path.abspath(__file__)) |
kjellander@webrtc.org | 8539bd0 | 2014-10-23 12:17:58 +0000 | [diff] [blame] | 36 | CHROMIUM_NO_HISTORY = 'CHROMIUM_NO_HISTORY' |
| 37 | |
| 38 | def _parse_gclient_dict(): |
| 39 | gclient_dict = {} |
| 40 | try: |
| 41 | main_gclient = os.path.join(os.path.dirname(ROOT_DIR), '.gclient') |
| 42 | with open(main_gclient, 'rb') as deps_content: |
| 43 | exec(deps_content, gclient_dict) |
| 44 | except Exception as e: |
| 45 | print >> sys.stderr, 'error while parsing .gclient:', e |
| 46 | return gclient_dict |
| 47 | |
| 48 | |
| 49 | def get_cache_dir(): |
| 50 | return _parse_gclient_dict().get('cache_dir') |
kjellander@webrtc.org | 8925662 | 2014-08-20 12:10:11 +0000 | [diff] [blame] | 51 | |
| 52 | |
| 53 | def get_target_os_list(): |
kjellander@webrtc.org | 8539bd0 | 2014-10-23 12:17:58 +0000 | [diff] [blame] | 54 | return ','.join(_parse_gclient_dict().get('target_os', [])) |
kjellander@webrtc.org | 8925662 | 2014-08-20 12:10:11 +0000 | [diff] [blame] | 55 | |
| 56 | |
| 57 | def main(): |
| 58 | CR_DIR = os.path.join(ROOT_DIR, 'chromium') |
| 59 | |
| 60 | p = argparse.ArgumentParser() |
| 61 | p.add_argument('--target-revision', required=True, |
| 62 | help='The target chromium git revision [REQUIRED]') |
| 63 | p.add_argument('--chromium-dir', default=CR_DIR, |
| 64 | help=('The path to the chromium directory to sync ' |
| 65 | '(default: %(default)r)')) |
| 66 | opts = p.parse_args() |
| 67 | opts.chromium_dir = os.path.abspath(opts.chromium_dir) |
| 68 | |
iannucci@chromium.org | 1613638 | 2014-08-21 15:48:23 +0000 | [diff] [blame] | 69 | target_os_list = get_target_os_list() |
| 70 | |
kjellander@webrtc.org | 8925662 | 2014-08-20 12:10:11 +0000 | [diff] [blame] | 71 | # Do a quick check to see if we were successful last time to make runhooks |
| 72 | # sooper fast. |
| 73 | flag_file = os.path.join(opts.chromium_dir, '.last_sync_chromium') |
iannucci@chromium.org | 1613638 | 2014-08-21 15:48:23 +0000 | [diff] [blame] | 74 | flag_file_content = '\n'.join([ |
| 75 | str(SCRIPT_VERSION), |
| 76 | opts.target_revision, |
| 77 | repr(target_os_list), |
| 78 | ]) |
kjellander@webrtc.org | dde19a6 | 2014-11-24 10:08:03 +0000 | [diff] [blame] | 79 | if (os.path.exists(os.path.join(opts.chromium_dir, 'src')) and |
| 80 | os.path.exists(flag_file)): |
kjellander@webrtc.org | 8925662 | 2014-08-20 12:10:11 +0000 | [diff] [blame] | 81 | with open(flag_file, 'r') as f: |
iannucci@chromium.org | 1613638 | 2014-08-21 15:48:23 +0000 | [diff] [blame] | 82 | if f.read() == flag_file_content: |
kjellander@webrtc.org | 8539bd0 | 2014-10-23 12:17:58 +0000 | [diff] [blame] | 83 | print 'Chromium already up to date: ', opts.target_revision |
kjellander@webrtc.org | 8925662 | 2014-08-20 12:10:11 +0000 | [diff] [blame] | 84 | return 0 |
| 85 | os.unlink(flag_file) |
| 86 | |
| 87 | env = os.environ.copy() |
kjellander@webrtc.org | 7d4e6d0 | 2014-11-27 10:41:04 +0000 | [diff] [blame] | 88 | |
| 89 | # Avoid downloading NaCl toolchain as part of the Chromium hooks. |
| 90 | env.setdefault('GYP_DEFINES', '') |
| 91 | env['GYP_DEFINES'] += ' disable_nacl=1' |
kjellander@webrtc.org | 8925662 | 2014-08-20 12:10:11 +0000 | [diff] [blame] | 92 | env['GYP_CHROMIUM_NO_ACTION'] = '1' |
| 93 | gclient_cmd = 'gclient.bat' if sys.platform.startswith('win') else 'gclient' |
| 94 | args = [ |
iannucci@chromium.org | 98d92d6 | 2014-08-20 23:53:59 +0000 | [diff] [blame] | 95 | gclient_cmd, 'sync', '--force', '--revision', 'src@'+opts.target_revision |
| 96 | ] |
| 97 | |
kjellander@webrtc.org | 3aa837c | 2014-08-20 14:25:43 +0000 | [diff] [blame] | 98 | if os.environ.get('CHROME_HEADLESS') == '1': |
kjellander@webrtc.org | 8539bd0 | 2014-10-23 12:17:58 +0000 | [diff] [blame] | 99 | # Running on a buildbot. |
kjellander@webrtc.org | 3aa837c | 2014-08-20 14:25:43 +0000 | [diff] [blame] | 100 | args.append('-vvv') |
| 101 | |
iannucci@chromium.org | 98d92d6 | 2014-08-20 23:53:59 +0000 | [diff] [blame] | 102 | if sys.platform.startswith('win'): |
iannucci@chromium.org | 286210d | 2014-08-21 02:14:11 +0000 | [diff] [blame] | 103 | cache_path = os.path.join(os.path.splitdrive(ROOT_DIR)[0] + os.path.sep, |
iannucci@chromium.org | 98d92d6 | 2014-08-20 23:53:59 +0000 | [diff] [blame] | 104 | 'b', 'git-cache') |
| 105 | else: |
| 106 | cache_path = '/b/git-cache' |
kjellander@webrtc.org | 8539bd0 | 2014-10-23 12:17:58 +0000 | [diff] [blame] | 107 | else: |
kjellander@webrtc.org | 7430433 | 2015-03-05 14:38:09 +0000 | [diff] [blame] | 108 | # Verbose, but not as verbose as on the buildbots. |
| 109 | args.append('-v') |
| 110 | |
kjellander@webrtc.org | 8539bd0 | 2014-10-23 12:17:58 +0000 | [diff] [blame] | 111 | # Support developers setting the cache_dir in .gclient. |
| 112 | cache_path = get_cache_dir() |
iannucci@chromium.org | 98d92d6 | 2014-08-20 23:53:59 +0000 | [diff] [blame] | 113 | |
kjellander@webrtc.org | 8539bd0 | 2014-10-23 12:17:58 +0000 | [diff] [blame] | 114 | # Allow for users with poor internet connections to download a Git clone |
| 115 | # without history (saves several gigs but is generally slower and doesn't work |
| 116 | # with the Git cache). |
| 117 | if os.environ.get(CHROMIUM_NO_HISTORY) == '1': |
| 118 | if cache_path: |
| 119 | print >> sys.stderr, ( |
| 120 | 'You cannot use "no-history" mode for syncing Chrome (i.e. set the ' |
| 121 | '%s environment variable to 1) when you have cache_dir configured in ' |
| 122 | 'your .gclient.' % CHROMIUM_NO_HISTORY) |
| 123 | return 1 |
| 124 | args.append('--no-history') |
| 125 | gclient_entries_file = os.path.join(opts.chromium_dir, '.gclient_entries') |
| 126 | else: |
| 127 | # Write a temporary .gclient file that has the cache_dir variable added. |
iannucci@chromium.org | 286210d | 2014-08-21 02:14:11 +0000 | [diff] [blame] | 128 | gclientfile = os.path.join(opts.chromium_dir, '.gclient') |
| 129 | with open(gclientfile, 'rb') as spec: |
iannucci@chromium.org | 98d92d6 | 2014-08-20 23:53:59 +0000 | [diff] [blame] | 130 | spec = spec.read().splitlines() |
| 131 | spec[-1] = 'cache_dir = %r' % (cache_path,) |
kjellander@webrtc.org | 8539bd0 | 2014-10-23 12:17:58 +0000 | [diff] [blame] | 132 | with open(gclientfile + '.tmp', 'wb') as f: |
iannucci@chromium.org | 286210d | 2014-08-21 02:14:11 +0000 | [diff] [blame] | 133 | f.write('\n'.join(spec)) |
| 134 | |
| 135 | args += [ |
kjellander@webrtc.org | 8539bd0 | 2014-10-23 12:17:58 +0000 | [diff] [blame] | 136 | '--gclientfile', '.gclient.tmp', |
iannucci@chromium.org | 286210d | 2014-08-21 02:14:11 +0000 | [diff] [blame] | 137 | '--delete_unversioned_trees', '--reset', '--upstream' |
| 138 | ] |
kjellander@webrtc.org | 6c6680a | 2014-09-27 18:41:03 +0000 | [diff] [blame] | 139 | gclient_entries_file = os.path.join(opts.chromium_dir, |
kjellander@webrtc.org | 8539bd0 | 2014-10-23 12:17:58 +0000 | [diff] [blame] | 140 | '.gclient.tmp_entries') |
kjellander@webrtc.org | 6c6680a | 2014-09-27 18:41:03 +0000 | [diff] [blame] | 141 | |
| 142 | # To avoid gclient sync problems when DEPS entries have been removed we must |
| 143 | # wipe the gclient's entries file that contains cached URLs for all DEPS. |
| 144 | if os.path.exists(gclient_entries_file): |
| 145 | os.unlink(gclient_entries_file) |
iannucci@chromium.org | 98d92d6 | 2014-08-20 23:53:59 +0000 | [diff] [blame] | 146 | |
kjellander@webrtc.org | 8925662 | 2014-08-20 12:10:11 +0000 | [diff] [blame] | 147 | if target_os_list: |
| 148 | args += ['--deps=' + target_os_list] |
| 149 | |
kjellander@webrtc.org | 7430433 | 2015-03-05 14:38:09 +0000 | [diff] [blame] | 150 | print textwrap.dedent("""\ |
| 151 | +--------------------------------------------------------------------+ |
| 152 | | NOTICE: This sync of Chromium will take a very long time the first | |
| 153 | | time you checkout WebRTC as several gigabytes of data has | |
| 154 | | to be downloaded. Make sure you don't abort this download | |
| 155 | | or you will have to issue a 'gclient sync' followed by a | |
| 156 | | 'git auto-svn' to complete the initial setup. If that | |
| 157 | | fails, you have to wipe everything clean and start over. | |
| 158 | +--------------------------------------------------------------------+""") |
kjellander@webrtc.org | 8925662 | 2014-08-20 12:10:11 +0000 | [diff] [blame] | 159 | print 'Running "%s" in %s' % (' '.join(args), opts.chromium_dir) |
| 160 | ret = subprocess.call(args, cwd=opts.chromium_dir, env=env) |
| 161 | if ret == 0: |
| 162 | with open(flag_file, 'wb') as f: |
iannucci@chromium.org | 1613638 | 2014-08-21 15:48:23 +0000 | [diff] [blame] | 163 | f.write(flag_file_content) |
kjellander@webrtc.org | 8925662 | 2014-08-20 12:10:11 +0000 | [diff] [blame] | 164 | |
| 165 | return ret |
| 166 | |
| 167 | |
| 168 | if __name__ == '__main__': |
| 169 | sys.exit(main()) |