| Index: build/android/pylib/utils/isolator.py
|
| diff --git a/build/android/pylib/utils/isolator.py b/build/android/pylib/utils/isolator.py
|
| deleted file mode 100644
|
| index f8177e007395c93769b21014315fd6beb7824b6b..0000000000000000000000000000000000000000
|
| --- a/build/android/pylib/utils/isolator.py
|
| +++ /dev/null
|
| @@ -1,192 +0,0 @@
|
| -# 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 fnmatch
|
| -import glob
|
| -import os
|
| -import shutil
|
| -import sys
|
| -import tempfile
|
| -
|
| -from devil.utils import cmd_helper
|
| -from pylib import constants
|
| -from pylib.constants import host_paths
|
| -
|
| -
|
| -_ISOLATE_SCRIPT = os.path.join(
|
| - host_paths.DIR_SOURCE_ROOT, 'tools', 'swarming_client', 'isolate.py')
|
| -
|
| -
|
| -def DefaultPathVariables():
|
| - return {
|
| - 'DEPTH': host_paths.DIR_SOURCE_ROOT,
|
| - 'PRODUCT_DIR': constants.GetOutDirectory(),
|
| - }
|
| -
|
| -
|
| -def DefaultConfigVariables():
|
| - # Note: This list must match the --config-vars in build/isolate.gypi
|
| - return {
|
| - 'CONFIGURATION_NAME': constants.GetBuildType(),
|
| - 'OS': 'android',
|
| - 'asan': '0',
|
| - 'branding': 'Chromium',
|
| - 'chromeos': '0',
|
| - 'component': 'static_library',
|
| - 'enable_pepper_cdms': '0',
|
| - 'enable_plugins': '0',
|
| - 'fastbuild': '0',
|
| - 'icu_use_data_file_flag': '1',
|
| - 'kasko': '0',
|
| - 'lsan': '0',
|
| - 'msan': '0',
|
| - # TODO(maruel): This may not always be true.
|
| - 'target_arch': 'arm',
|
| - 'tsan': '0',
|
| - 'use_custom_libcxx': '0',
|
| - 'use_instrumented_libraries': '0',
|
| - 'use_prebuilt_instrumented_libraries': '0',
|
| - 'use_ozone': '0',
|
| - 'use_x11': '0',
|
| - 'v8_use_external_startup_data': '1',
|
| - 'msvs_version': '0',
|
| - }
|
| -
|
| -
|
| -def IsIsolateEmpty(isolate_path):
|
| - """Returns whether there are no files in the .isolate."""
|
| - with open(isolate_path) as f:
|
| - return "'files': []" in f.read()
|
| -
|
| -
|
| -class Isolator(object):
|
| - """Manages calls to isolate.py for the android test runner scripts."""
|
| -
|
| - def __init__(self):
|
| - self._isolate_deps_dir = tempfile.mkdtemp()
|
| -
|
| - @property
|
| - def isolate_deps_dir(self):
|
| - return self._isolate_deps_dir
|
| -
|
| - def Clear(self):
|
| - """Deletes the isolate dependency directory."""
|
| - if os.path.exists(self._isolate_deps_dir):
|
| - shutil.rmtree(self._isolate_deps_dir)
|
| -
|
| - def Remap(self, isolate_abs_path, isolated_abs_path,
|
| - path_variables=None, config_variables=None):
|
| - """Remaps data dependencies into |self._isolate_deps_dir|.
|
| -
|
| - Args:
|
| - isolate_abs_path: The absolute path to the .isolate file, which specifies
|
| - data dependencies in the source tree.
|
| - isolated_abs_path: The absolute path to the .isolated file, which is
|
| - generated by isolate.py and specifies data dependencies in
|
| - |self._isolate_deps_dir| and their digests.
|
| - path_variables: A dict containing everything that should be passed
|
| - as a |--path-variable| to the isolate script. Defaults to the return
|
| - value of |DefaultPathVariables()|.
|
| - config_variables: A dict containing everything that should be passed
|
| - as a |--config-variable| to the isolate script. Defaults to the return
|
| - value of |DefaultConfigVariables()|.
|
| - Raises:
|
| - Exception if the isolate command fails for some reason.
|
| - """
|
| - if not path_variables:
|
| - path_variables = DefaultPathVariables()
|
| - if not config_variables:
|
| - config_variables = DefaultConfigVariables()
|
| -
|
| - isolate_cmd = [
|
| - sys.executable, _ISOLATE_SCRIPT, 'remap',
|
| - '--isolate', isolate_abs_path,
|
| - '--isolated', isolated_abs_path,
|
| - '--outdir', self._isolate_deps_dir,
|
| - ]
|
| - for k, v in path_variables.iteritems():
|
| - isolate_cmd.extend(['--path-variable', k, v])
|
| - for k, v in config_variables.iteritems():
|
| - isolate_cmd.extend(['--config-variable', k, v])
|
| -
|
| - exit_code, _ = cmd_helper.GetCmdStatusAndOutput(isolate_cmd)
|
| - if exit_code:
|
| - raise Exception('isolate command failed: %s' % ' '.join(isolate_cmd))
|
| -
|
| - def VerifyHardlinks(self):
|
| - """Checks |isolate_deps_dir| for a hardlink.
|
| -
|
| - Returns:
|
| - True if a hardlink is found.
|
| - False if nothing is found.
|
| - Raises:
|
| - Exception if a non-hardlink is found.
|
| - """
|
| - for root, _, filenames in os.walk(self._isolate_deps_dir):
|
| - if filenames:
|
| - linked_file = os.path.join(root, filenames[0])
|
| - orig_file = os.path.join(
|
| - self._isolate_deps_dir,
|
| - os.path.relpath(linked_file, self._isolate_deps_dir))
|
| - if os.stat(linked_file).st_ino == os.stat(orig_file).st_ino:
|
| - return True
|
| - else:
|
| - raise Exception('isolate remap command did not use hardlinks.')
|
| - return False
|
| -
|
| - def PurgeExcluded(self, deps_exclusion_list):
|
| - """Deletes anything on |deps_exclusion_list| from |self._isolate_deps_dir|.
|
| -
|
| - Args:
|
| - deps_exclusion_list: A list of globs to exclude from the isolate
|
| - dependency directory.
|
| - """
|
| - excluded_paths = (
|
| - x for y in deps_exclusion_list
|
| - for x in glob.glob(
|
| - os.path.abspath(os.path.join(self._isolate_deps_dir, y))))
|
| - for p in excluded_paths:
|
| - if os.path.isdir(p):
|
| - shutil.rmtree(p)
|
| - else:
|
| - os.remove(p)
|
| -
|
| - @classmethod
|
| - def _DestructiveMerge(cls, src, dest):
|
| - if os.path.exists(dest) and os.path.isdir(dest):
|
| - for p in os.listdir(src):
|
| - cls._DestructiveMerge(os.path.join(src, p), os.path.join(dest, p))
|
| - os.rmdir(src)
|
| - else:
|
| - shutil.move(src, dest)
|
| -
|
| -
|
| - def MoveOutputDeps(self):
|
| - """Moves files from the output directory to the top level of
|
| - |self._isolate_deps_dir|.
|
| -
|
| - Moves pak files from the output directory to to <isolate_deps_dir>/paks
|
| - Moves files from the product directory to <isolate_deps_dir>
|
| - """
|
| - # On Android, all pak files need to be in the top-level 'paks' directory.
|
| - paks_dir = os.path.join(self._isolate_deps_dir, 'paks')
|
| - os.mkdir(paks_dir)
|
| -
|
| - deps_out_dir = os.path.join(
|
| - self._isolate_deps_dir,
|
| - os.path.relpath(os.path.join(constants.GetOutDirectory(), os.pardir),
|
| - host_paths.DIR_SOURCE_ROOT))
|
| - for root, _, filenames in os.walk(deps_out_dir):
|
| - for filename in fnmatch.filter(filenames, '*.pak'):
|
| - shutil.move(os.path.join(root, filename), paks_dir)
|
| -
|
| - # Move everything in PRODUCT_DIR to top level.
|
| - deps_product_dir = os.path.join(
|
| - deps_out_dir, os.path.basename(constants.GetOutDirectory()))
|
| - if os.path.isdir(deps_product_dir):
|
| - for p in os.listdir(deps_product_dir):
|
| - Isolator._DestructiveMerge(os.path.join(deps_product_dir, p),
|
| - os.path.join(self._isolate_deps_dir, p))
|
| - os.rmdir(deps_product_dir)
|
| - os.rmdir(deps_out_dir)
|
|
|