Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 #!/usr/bin/env python | 1 #!/usr/bin/env python |
| 2 # Copyright (c) 2015 The Chromium Authors. All rights reserved. | 2 # Copyright (c) 2015 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 | 6 |
| 7 """Wrapper for updating and calling infra.git tools. | 7 """Wrapper for updating and calling infra.git tools. |
| 8 | 8 |
| 9 This tool does a two things: | 9 This tool does a two things: |
| 10 * Maintains a infra.git checkout pinned at "deployed" in the home dir | 10 * Maintains a infra.git checkout pinned at "deployed" in the home dir |
| 11 * Acts as an alias to infra.tools.* | 11 * Acts as an alias to infra.tools.* |
| 12 * Acts as an alias to infra.git/cipd/<executable> | |
| 12 """ | 13 """ |
| 13 | 14 |
| 14 # TODO(hinoka): Use cipd/glyco instead of git/gclient. | 15 # TODO(hinoka): Use cipd/glyco instead of git/gclient. |
| 15 | 16 |
| 16 import argparse | 17 import argparse |
| 17 import sys | 18 import sys |
| 18 import os | 19 import os |
| 19 import subprocess | 20 import subprocess |
| 20 import re | 21 import re |
| 21 | 22 |
| (...skipping 27 matching lines...) Expand all Loading... | |
| 49 | 50 |
| 50 subprocess.check_call( | 51 subprocess.check_call( |
| 51 ['git', 'fetch', 'origin'], cwd=INFRA_DIR, | 52 ['git', 'fetch', 'origin'], cwd=INFRA_DIR, |
| 52 stdout=subprocess.PIPE, stderr=subprocess.STDOUT) | 53 stdout=subprocess.PIPE, stderr=subprocess.STDOUT) |
| 53 origin_rev = get_git_rev(INFRA_DIR, 'origin/%s' % (branch,)) | 54 origin_rev = get_git_rev(INFRA_DIR, 'origin/%s' % (branch,)) |
| 54 return origin_rev != local_rev | 55 return origin_rev != local_rev |
| 55 | 56 |
| 56 | 57 |
| 57 def ensure_infra(branch): | 58 def ensure_infra(branch): |
| 58 """Ensures that infra.git is present in ~/.chrome-infra.""" | 59 """Ensures that infra.git is present in ~/.chrome-infra.""" |
| 59 sys.stderr.write( | 60 print 'Fetching infra@%s into %s, may take a couple of minutes...' % ( |
| 60 'Fetching infra@%s into %s, may take a couple of minutes...' % ( | 61 branch, TARGET_DIR) |
| 61 branch, TARGET_DIR)) | |
| 62 sys.stderr.flush() | |
|
tandrii(chromium)
2016/07/14 12:59:26
you really don't like my stderr writing :(
the pur
Ryan Tseng
2016/07/14 20:27:11
Oops I think this was a mistake, or I rebased badl
| |
| 63 if not os.path.isdir(TARGET_DIR): | 62 if not os.path.isdir(TARGET_DIR): |
| 64 os.mkdir(TARGET_DIR) | 63 os.mkdir(TARGET_DIR) |
| 65 if not os.path.exists(os.path.join(TARGET_DIR, '.gclient')): | 64 if not os.path.exists(os.path.join(TARGET_DIR, '.gclient')): |
| 66 subprocess.check_call( | 65 subprocess.check_call( |
| 67 [sys.executable, os.path.join(SCRIPT_DIR, 'fetch.py'), 'infra'], | 66 [sys.executable, os.path.join(SCRIPT_DIR, 'fetch.py'), 'infra'], |
| 68 cwd=TARGET_DIR, | 67 cwd=TARGET_DIR, |
| 69 stdout=subprocess.PIPE) | 68 stdout=subprocess.PIPE) |
| 70 subprocess.check_call( | 69 subprocess.check_call( |
| 71 [sys.executable, GCLIENT, 'sync', '--revision', 'origin/%s' % (branch,)], | 70 [sys.executable, GCLIENT, 'sync', '--revision', 'origin/%s' % (branch,)], |
| 72 cwd=TARGET_DIR, | 71 cwd=TARGET_DIR, |
| 73 stdout=subprocess.PIPE) | 72 stdout=subprocess.PIPE) |
| 74 sys.stderr.write(' done.\n') | 73 |
| 75 sys.stderr.flush() | 74 |
| 75 def is_exe(filename): | |
| 76 """Given a full filepath, return true if the file is an executable.""" | |
| 77 if sys.platform.startswith('win'): | |
| 78 return filename.endswith('.exe') | |
| 79 else: | |
| 80 return os.path.isfile(filename) and os.access(filename, os.X_OK) | |
| 76 | 81 |
| 77 | 82 |
| 78 def get_available_tools(): | 83 def get_available_tools(): |
| 79 tools = [] | 84 """Returns a tuple of (list of infra tools, list of cipd tools)""" |
| 85 infra_tools = [] | |
| 86 cipd_tools = [] | |
| 80 starting = os.path.join(TARGET_DIR, 'infra', 'infra', 'tools') | 87 starting = os.path.join(TARGET_DIR, 'infra', 'infra', 'tools') |
| 81 for root, _, files in os.walk(starting): | 88 for root, _, files in os.walk(starting): |
| 82 if '__main__.py' in files: | 89 if '__main__.py' in files: |
| 83 tools.append(root[len(starting)+1:].replace(os.path.sep, '.')) | 90 infra_tools.append(root[len(starting)+1:].replace(os.path.sep, '.')) |
| 84 return sorted(tools) | 91 cipd = os.path.join(TARGET_DIR, 'infra', 'cipd') |
| 92 for fn in os.listdir(cipd): | |
| 93 if is_exe(os.path.join(cipd, fn)): | |
| 94 cipd_tools.append(fn) | |
| 95 return (sorted(infra_tools), sorted(cipd_tools)) | |
| 85 | 96 |
| 86 | 97 |
| 87 def run(args): | 98 def run(args): |
| 88 if args: | 99 if args: |
| 89 tool_name = args[0] | 100 tool_name = args[0] |
| 90 cmd = [ | 101 # Check to see if it is a infra tool first. |
| 91 sys.executable, os.path.join(TARGET_DIR, 'infra', 'run.py'), | 102 infra_dir = os.path.join( |
| 92 'infra.tools.%s' % tool_name] | 103 TARGET_DIR, 'infra', 'infra', 'tools', *tool_name.split('.')) |
| 104 cipd_file = os.path.join(TARGET_DIR, 'infra', 'cipd', tool_name) | |
| 105 if sys.platform.startswith('win'): | |
| 106 cipd_file += '.exe' | |
| 107 if (os.path.isdir(infra_dir) | |
| 108 and os.path.isfile(os.path.join(infra_dir, '__main__.py'))): | |
| 109 cmd = [ | |
| 110 sys.executable, os.path.join(TARGET_DIR, 'infra', 'run.py'), | |
| 111 'infra.tools.%s' % tool_name] | |
| 112 elif os.path.isfile(cipd_file) and is_exe(cipd_file): | |
| 113 cmd = [cipd_file] | |
| 114 | |
| 115 # Add the remaining arguments. | |
| 93 cmd.extend(args[1:]) | 116 cmd.extend(args[1:]) |
| 94 return subprocess.call(cmd) | 117 return subprocess.call(cmd) |
| 95 | 118 |
| 96 tools = get_available_tools() | 119 infra_tools, cipd_tools = get_available_tools() |
| 97 print """usage: cit.py <name of tool> [args for tool] | 120 print """usage: cit.py <name of tool> [args for tool] |
| 98 | 121 |
| 99 Wrapper for maintaining and calling tools in "infra.git/run.py infra.tools.*" | 122 Wrapper for maintaining and calling tools in: |
| 123 "infra.git/run.py infra.tools.*" | |
| 124 "infra.git/cipd/*" | |
| 100 | 125 |
| 101 Available tools are: | 126 Available infra tools are:""" |
| 102 """ | 127 for tool in infra_tools: |
| 103 for tool in tools: | |
| 104 print ' * %s' % tool | 128 print ' * %s' % tool |
| 105 | 129 |
| 130 print """ | |
| 131 Available cipd tools are:""" | |
| 132 for tool in cipd_tools: | |
| 133 print ' * %s' % tool | |
| 134 | |
| 135 | |
| 106 | 136 |
| 107 def main(): | 137 def main(): |
| 108 parser = argparse.ArgumentParser("Chrome Infrastructure CLI.") | 138 parser = argparse.ArgumentParser("Chrome Infrastructure CLI.") |
| 109 parser.add_argument('-b', '--infra-branch', default='deployed', | 139 parser.add_argument('-b', '--infra-branch', default='deployed', |
| 110 help="The name of the 'infra' branch to use (default is %(default)s).") | 140 help="The name of the 'infra' branch to use (default is %(default)s).") |
| 111 parser.add_argument('args', nargs=argparse.REMAINDER) | 141 parser.add_argument('args', nargs=argparse.REMAINDER) |
| 112 | 142 |
| 113 args, extras = parser.parse_known_args() | 143 args, extras = parser.parse_known_args() |
| 114 if args.args and args.args[0] == '--': | 144 if args.args and args.args[0] == '--': |
| 115 args.args.pop(0) | 145 args.args.pop(0) |
| 116 if extras: | 146 if extras: |
| 117 args.args = extras + args.args | 147 args.args = extras + args.args |
| 118 | 148 |
| 119 if need_to_update(args.infra_branch): | 149 if need_to_update(args.infra_branch): |
| 120 ensure_infra(args.infra_branch) | 150 ensure_infra(args.infra_branch) |
| 121 return run(args.args) | 151 return run(args.args) |
| 122 | 152 |
| 123 if __name__ == '__main__': | 153 if __name__ == '__main__': |
| 124 sys.exit(main()) | 154 sys.exit(main()) |
| OLD | NEW |