Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 #!/usr/bin/env python | 1 #!/usr/bin/env python |
| 2 # Copyright 2015 The Chromium Authors. All rights reserved. | 2 # Copyright 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 '''Bundles the Blimp Engine and its runtime dependencies into a tarball. | 6 '''Bundles the Blimp target and its runtime dependencies into a tarball. |
| 7 | 7 |
| 8 The created bundle can be passed as input to docker build. E.g. | 8 The created bundle can be passed as input to docker build. E.g. |
| 9 docker build - < ../../out-linux/Debug/blimp_engine_deps.tar.gz | 9 docker build - < ../../out-linux/Debug/blimp_engine_deps.tar.gz |
| 10 ''' | 10 ''' |
| 11 | 11 |
| 12 | 12 |
| 13 import argparse | 13 import argparse |
| 14 import os | 14 import os |
| 15 import subprocess | 15 import subprocess |
| 16 import sys | 16 import sys |
| (...skipping 16 matching lines...) Expand all Loading... | |
| 33 parser = argparse.ArgumentParser(description=__doc__) | 33 parser = argparse.ArgumentParser(description=__doc__) |
| 34 parser.add_argument('--build-dir', | 34 parser.add_argument('--build-dir', |
| 35 help=('build output directory (e.g. out/Debug)'), | 35 help=('build output directory (e.g. out/Debug)'), |
| 36 required=True, | 36 required=True, |
| 37 metavar='DIR') | 37 metavar='DIR') |
| 38 parser.add_argument('--dockerfile', | 38 parser.add_argument('--dockerfile', |
| 39 help=('Dockerfile to add to the bundle'), | 39 help=('Dockerfile to add to the bundle'), |
| 40 required=True, | 40 required=True, |
| 41 metavar='FILE') | 41 metavar='FILE') |
| 42 parser.add_argument('--startup-script', | 42 parser.add_argument('--startup-script', |
| 43 help=('Engine startup script to add to the bundle'), | 43 help=('startup script to add to the bundle'), |
|
maniscalco
2016/06/02 19:15:55
Consider mentioning that this script is optional i
Jess
2016/06/02 23:02:15
Done.
| |
| 44 required=True, | 44 required=False, |
| 45 metavar='FILE') | 45 metavar='FILE') |
| 46 parser.add_argument('--manifest', | 46 parser.add_argument('--manifest', |
| 47 help=('engine manifest'), | 47 help=('manifest for bundle'), |
| 48 required=True) | 48 required=True) |
| 49 parser.add_argument('--output', | 49 parser.add_argument('--output', |
| 50 help=('name and path of bundle to create'), | 50 help=('name and path of bundle to create'), |
| 51 required=True, | 51 required=True, |
| 52 metavar='FILE') | 52 metavar='FILE') |
| 53 args = parser.parse_args() | 53 args = parser.parse_args() |
| 54 | 54 |
| 55 deps = ReadDependencies(args.manifest) | 55 deps = ReadDependencies(args.manifest) |
| 56 | 56 |
| 57 dockerfile_dirname, dockerfile_basename = os.path.split(args.dockerfile) | 57 dockerfile_dirname, dockerfile_basename = os.path.split(args.dockerfile) |
| 58 startup_script_dirname, startup_script_basename = os.path.split( | 58 if args.startup_script: |
| 59 args.startup_script) | 59 startup_script_dirname, startup_script_basename = os.path.split( |
| 60 args.startup_script) | |
| 60 | 61 |
| 61 try: | 62 try: |
| 62 env = os.environ.copy() | 63 env = os.environ.copy() |
| 63 # Use fastest possible mode when gzipping. | 64 # Use fastest possible mode when gzipping. |
| 64 env["GZIP"] = "-1" | 65 env["GZIP"] = "-1" |
| 66 subprocess_args = [ | |
| 67 "tar", | |
| 68 "-zcf", args.output, | |
| 69 # Ensure tarball content group permissions are appropriately set for | |
| 70 # use as part of a "docker build". That is group readable with | |
| 71 # executable files also being group executable. | |
| 72 "--mode=g+rX", | |
| 73 "-C", dockerfile_dirname, dockerfile_basename, | |
| 74 "-C", args.build_dir] + deps | |
| 75 if args.startup_script: | |
| 76 startup_script_dirname, startup_script_basename = os.path.split( | |
| 77 args.startup_script) | |
| 78 subprocess_args.extend( | |
| 79 ["-C", startup_script_dirname, startup_script_basename]) | |
| 65 subprocess.check_output( | 80 subprocess.check_output( |
| 66 ["tar", | 81 subprocess_args, |
| 67 "-zcf", args.output, | |
| 68 # Ensure tarball content group permissions are appropriately set for | |
| 69 # use as part of a "docker build". That is group readable with | |
| 70 # executable files also being group executable. | |
| 71 "--mode=g+rX", | |
| 72 "-C", dockerfile_dirname, dockerfile_basename, | |
| 73 "-C", startup_script_dirname, startup_script_basename, | |
| 74 "-C", args.build_dir] + deps, | |
| 75 # Redirect stderr to stdout, so that its output is captured. | 82 # Redirect stderr to stdout, so that its output is captured. |
| 76 stderr=subprocess.STDOUT, | 83 stderr=subprocess.STDOUT, |
| 77 env=env) | 84 env=env) |
| 78 except subprocess.CalledProcessError as e: | 85 except subprocess.CalledProcessError as e: |
| 79 print >> sys.stderr, "Failed to create tarball:" | 86 print >> sys.stderr, "Failed to create tarball:" |
| 80 print >> sys.stderr, e.output | 87 print >> sys.stderr, e.output |
| 81 sys.exit(1) | 88 sys.exit(1) |
| 82 | 89 |
| 83 if __name__ == "__main__": | 90 if __name__ == "__main__": |
| 84 main() | 91 main() |
| OLD | NEW |