| Index: tools/upload_service.py
|
| diff --git a/tools/upload_service.py b/tools/upload_service.py
|
| deleted file mode 100755
|
| index 91ab49bb1d453e3655a424c99a669a17ee2b9d5e..0000000000000000000000000000000000000000
|
| --- a/tools/upload_service.py
|
| +++ /dev/null
|
| @@ -1,207 +0,0 @@
|
| -#!/usr/bin/env python
|
| -# Copyright 2014 The Chromium Authors. All rights reserved.
|
| -# Use of this source code is governed by a BSD-style license that can be
|
| -# found in the LICENSE file.
|
| -
|
| -import argparse
|
| -import glob
|
| -import imp
|
| -import itertools
|
| -import os
|
| -import subprocess
|
| -import sys
|
| -import tempfile
|
| -import time
|
| -import zipfile
|
| -
|
| -sys.path.append(os.path.join(os.path.dirname(__file__),
|
| - os.pardir, 'third_party', 'pyelftools'))
|
| -import elftools.elf.elffile as elffile
|
| -
|
| -sys.path.append(os.path.join(os.path.dirname(__file__),
|
| - os.pardir, 'third_party', 'mojo_devtools'))
|
| -import android_gdb.signatures as signatures
|
| -
|
| -SERVICES = ["network_service", "network_service_apptests"]
|
| -
|
| -# A service does not need to expose interfaces. Those that do expose interfaces
|
| -# have their mojoms located in the directories listed below, in paths relative
|
| -# to the directory of this script.
|
| -MOJOMS_IN_DIR = {
|
| - "network_service": os.path.join("network", "public", "interfaces")
|
| -}
|
| -
|
| -# The network service is downloaded out-of-band rather than dynamically by the
|
| -# shell and thus can be stored zipped in the cloud. Other services are intended
|
| -# to be downloaded dynamically by the shell, which doesn't currently understand
|
| -# zipped binaries.
|
| -SERVICES_WITH_ZIPPED_BINARIES = ["network_service", "network_service_apptests"]
|
| -
|
| -if not sys.platform.startswith("linux"):
|
| - print "Only support linux for now"
|
| - sys.exit(1)
|
| -
|
| -root_path = os.path.realpath(os.path.dirname(__file__))
|
| -
|
| -find_depot_tools_path = os.path.join(root_path, "find_depot_tools.py")
|
| -find_depot_tools = imp.load_source("find_depot_tools", find_depot_tools_path)
|
| -
|
| -depot_tools_path = find_depot_tools.add_depot_tools_to_path()
|
| -gsutil_exe = os.path.join(depot_tools_path, "third_party", "gsutil", "gsutil")
|
| -
|
| -def get_version_name(custom_build):
|
| - if custom_build:
|
| - branch = subprocess.check_output(
|
| - ["git", "rev-parse", "--abbrev-ref", "HEAD"], cwd=root_path).strip()
|
| - try:
|
| - base = subprocess.check_output(
|
| - ["git", "config", "--get", "branch." + branch + ".base"],
|
| - cwd=root_path).strip()
|
| - issue = subprocess.check_output(
|
| - ["git", "config", "--get", "branch." + branch + ".rietveldissue"],
|
| - cwd=root_path).strip()
|
| - patchset = subprocess.check_output(
|
| - ["git", "config", "--get", "branch." + branch + ".rietveldpatchset"],
|
| - cwd=root_path).strip()
|
| - except subprocess.CalledProcessError:
|
| - return None
|
| -
|
| - if not base or not issue or not patchset:
|
| - return None
|
| - else:
|
| - return "custom_build_base_%s_issue_%s_patchset_%s" % (base, issue,
|
| - patchset)
|
| - else:
|
| - return subprocess.check_output(["git", "rev-parse", "HEAD"],
|
| - cwd=root_path).strip()
|
| -
|
| -def gsutil_cp(source, dest, dry_run):
|
| - if dry_run:
|
| - print "gsutil cp %s %s" % (source, dest)
|
| - else:
|
| - subprocess.check_call([gsutil_exe, "cp", source, dest])
|
| -
|
| -
|
| -def upload_mojoms(version_name, service, absolute_mojom_directory_path,
|
| - dry_run):
|
| - dest = "gs://mojo/" + service + "/" + version_name + "/" + "mojoms.zip"
|
| -
|
| - with tempfile.NamedTemporaryFile() as mojom_zip_file:
|
| - with zipfile.ZipFile(mojom_zip_file, 'w') as z:
|
| - for root, _, files in os.walk(absolute_mojom_directory_path):
|
| - for filename in files:
|
| - absolute_file_path = os.path.join(root, filename)
|
| - relative_file_path = os.path.relpath(absolute_file_path, root)
|
| - z.write(absolute_file_path, relative_file_path)
|
| - gsutil_cp(mojom_zip_file.name, dest, dry_run)
|
| -
|
| -
|
| -def upload_symbols(binary_dir, dry_run):
|
| - dest_dir = "gs://mojo/symbols/"
|
| - symbols_dir = os.path.join(binary_dir, "symbols")
|
| - for name in os.listdir(symbols_dir):
|
| - path = os.path.join(symbols_dir, name)
|
| - with open(path) as f:
|
| - signature = signatures.get_signature(f, elffile)
|
| - if signature is not None:
|
| - dest = dest_dir + signature
|
| - gsutil_cp(path, dest, dry_run)
|
| -
|
| -def upload_binary(version_name, service, binary_dir, platform, dry_run):
|
| - dest_dir = "gs://mojo/" + service + "/" + version_name + "/" + platform + "/"
|
| - should_zip = service in SERVICES_WITH_ZIPPED_BINARIES
|
| - binary_name = service + ".mojo"
|
| - absolute_binary_path = os.path.join(root_path, binary_dir, binary_name)
|
| -
|
| - if not should_zip:
|
| - # Upload the binary.
|
| - dest = dest_dir + binary_name
|
| - gsutil_cp(absolute_binary_path, dest, dry_run)
|
| -
|
| - # Update the pointer to the service's location to point to the
|
| - # newly-uploaded binary.
|
| - service_location = dest.replace("gs://", "https://storage.googleapis.com/")
|
| - location_file = ("gs://mojo/services/" + platform + "/" + service +
|
| - "_location")
|
| - with tempfile.NamedTemporaryFile() as tmp:
|
| - tmp.write(service_location)
|
| - tmp.flush()
|
| - gsutil_cp(tmp.name, location_file, dry_run)
|
| - return
|
| -
|
| - # Zip the binary before uploading it to the cloud.
|
| - dest = dest_dir + binary_name + ".zip"
|
| - with tempfile.NamedTemporaryFile() as binary_zip_file:
|
| - with zipfile.ZipFile(binary_zip_file, 'w') as z:
|
| - with open(absolute_binary_path) as service_binary:
|
| - zipinfo = zipfile.ZipInfo(binary_name)
|
| - zipinfo.external_attr = 0o777 << 16
|
| - zipinfo.compress_type = zipfile.ZIP_DEFLATED
|
| - zipinfo.date_time = time.gmtime(os.path.getmtime(absolute_binary_path))
|
| - z.writestr(zipinfo, service_binary.read())
|
| - gsutil_cp(binary_zip_file.name, dest, dry_run)
|
| -
|
| -
|
| -def main():
|
| - parser = argparse.ArgumentParser(
|
| - description="Upload service mojoms and binaries to Google storage")
|
| - parser.add_argument("-n", "--dry-run", action="store_true", help="Dry run")
|
| - parser.add_argument(
|
| - "--linux-x64-binary-dir",
|
| - help="Path to the dir containing the linux-x64 service binary relative "
|
| - "to the repo root, e.g. out/Release")
|
| - parser.add_argument(
|
| - "--android-arm-binary-dir",
|
| - help="Path to the dir containing the android-arm service binary relative "
|
| - "to the repo root, e.g. out/android_Release")
|
| - parser.add_argument("service",
|
| - help="The service to be uploaded (one of %s)" % SERVICES)
|
| - parser.add_argument(
|
| - "--custom-build", action="store_true",
|
| - help="Indicates that this is a build with change that is not committed. "
|
| - "The change must be uploaded to Rietveld. The script needs to be "
|
| - "run from the branch associated with the change.")
|
| - parser.add_argument(
|
| - "--upload-symbols", action="store_true",
|
| - help="Indicates that this should also upload all symbols.")
|
| - args = parser.parse_args()
|
| -
|
| - if args.service not in SERVICES:
|
| - print args.service + " is not one of the recognized services:"
|
| - print SERVICES
|
| - return 1
|
| -
|
| - version_name = get_version_name(args.custom_build)
|
| - if args.custom_build and not version_name:
|
| - print ("When uploading a custom build, the corresponding change to source "
|
| - "code must be uploaded to Rietveld. Besides, this script needs to "
|
| - "be run from the branch associated with the change.")
|
| - return 1
|
| -
|
| - if args.service in MOJOMS_IN_DIR:
|
| - script_dir = os.path.dirname(os.path.realpath(__file__))
|
| - absolute_mojom_directory_path = os.path.join(script_dir,
|
| - MOJOMS_IN_DIR[args.service])
|
| - upload_mojoms(version_name, args.service, absolute_mojom_directory_path,
|
| - args.dry_run)
|
| -
|
| - if args.linux_x64_binary_dir:
|
| - upload_binary(version_name, args.service, args.linux_x64_binary_dir,
|
| - "linux-x64", args.dry_run)
|
| - if args.upload_symbols:
|
| - upload_symbols(args.linux_x64_binary_dir, args.dry_run)
|
| -
|
| - if args.android_arm_binary_dir:
|
| - upload_binary(version_name, args.service, args.android_arm_binary_dir,
|
| - "android-arm", args.dry_run)
|
| - if args.upload_symbols:
|
| - upload_symbols(args.android_arm_binary_dir, args.dry_run)
|
| -
|
| - if not args.dry_run:
|
| - print "Uploaded artifacts for version %s" % (version_name, )
|
| - else:
|
| - print "No artifacts uploaded (dry run)"
|
| - return 0
|
| -
|
| -if __name__ == '__main__':
|
| - sys.exit(main())
|
|
|