Index: infra/bots/flavor/android_flavor.py |
diff --git a/infra/bots/flavor/android_flavor.py b/infra/bots/flavor/android_flavor.py |
deleted file mode 100644 |
index 5a30079951dc6c21c740950ef746c9cd46366fbd..0000000000000000000000000000000000000000 |
--- a/infra/bots/flavor/android_flavor.py |
+++ /dev/null |
@@ -1,241 +0,0 @@ |
-#!/usr/bin/env python |
-# |
-# Copyright 2016 Google Inc. |
-# |
-# Use of this source code is governed by a BSD-style license that can be |
-# found in the LICENSE file. |
- |
- |
-import android_devices |
-import default_flavor |
-import os |
- |
- |
-"""Android flavor utils, used for building for and running tests on Android.""" |
- |
- |
-class _ADBWrapper(object): |
- """Wrapper for ADB.""" |
- def __init__(self, path_to_adb, serial, android_flavor): |
- self._adb = path_to_adb |
- self._serial = serial |
- self._wait_count = 0 |
- self._android_flavor = android_flavor |
- |
- def wait_for_device(self): |
- """Run 'adb wait-for-device'.""" |
- self._wait_count += 1 |
- cmd = [ |
- os.path.join(self._android_flavor.android_bin, 'adb_wait_for_device'), |
- '-s', self._serial, |
- ] |
- self._android_flavor._bot_info.run( |
- cmd, env=self._android_flavor._default_env) |
- |
- def maybe_wait_for_device(self): |
- """Run 'adb wait-for-device' if it hasn't already been run.""" |
- if self._wait_count == 0: |
- self.wait_for_device() |
- |
- def __call__(self, *args, **kwargs): |
- self.maybe_wait_for_device() |
- return self._android_flavor._bot_info.run(self._adb + args, **kwargs) |
- |
- |
-class AndroidFlavorUtils(default_flavor.DefaultFlavorUtils): |
- def __init__(self, skia_api): |
- super(AndroidFlavorUtils, self).__init__(skia_api) |
- self.device = self._bot_info.spec['device_cfg'] |
- slave_info = android_devices.SLAVE_INFO.get( |
- self._bot_info.slave_name, |
- android_devices.SLAVE_INFO['default']) |
- self.serial = slave_info.serial |
- self.android_bin = os.path.join( |
- self._bot_info.skia_dir, 'platform_tools', 'android', 'bin') |
- self._android_sdk_root = slave_info.android_sdk_root |
- self._adb = _ADBWrapper( |
- os.path.join(self._android_sdk_root, 'platform-tools', 'adb'), |
- self.serial, |
- self) |
- self._has_root = slave_info.has_root |
- self._default_env = {'ANDROID_SDK_ROOT': self._android_sdk_root, |
- 'ANDROID_HOME': self._android_sdk_root, |
- 'SKIA_ANDROID_VERBOSE_SETUP': '1'} |
- |
- def step(self, name, cmd, env=None, **kwargs): |
- self._adb.maybe_wait_for_device() |
- args = [self.android_bin.join('android_run_skia'), |
- '--verbose', |
- '--logcat', |
- '-d', self.device, |
- '-s', self.serial, |
- '-t', self._bot_info.configuration, |
- ] |
- env = dict(env or {}) |
- env.update(self._default_env) |
- |
- return self._bot_info.run(self._bot_info.m.step, name=name, cmd=args + cmd, |
- env=env, **kwargs) |
- |
- def compile(self, target): |
- """Build the given target.""" |
- env = dict(self._default_env) |
- ccache = self._bot_info.ccache |
- if ccache: |
- env['ANDROID_MAKE_CCACHE'] = ccache |
- |
- cmd = [os.path.join(self.android_bin, 'android_ninja'), target, |
- '-d', self.device] |
- if 'Clang' in self._bot_info.name: |
- cmd.append('--clang') |
- self._bot_info.run(cmd, env=env) |
- |
- def device_path_join(self, *args): |
- """Like os.path.join(), but for paths on a connected Android device.""" |
- return '/'.join(args) |
- |
- def device_path_exists(self, path): |
- """Like os.path.exists(), but for paths on a connected device.""" |
- exists_str = 'FILE_EXISTS' |
- return exists_str in self._adb( |
- name='exists %s' % self._bot_info.m.path.basename(path), |
- serial=self.serial, |
- cmd=['shell', 'if', '[', '-e', path, '];', |
- 'then', 'echo', exists_str + ';', 'fi'], |
- stdout=self._bot_info.m.raw_io.output(), |
- infra_step=True |
- ).stdout |
- |
- def _remove_device_dir(self, path): |
- """Remove the directory on the device.""" |
- self._adb(name='rmdir %s' % self._bot_info.m.path.basename(path), |
- serial=self.serial, |
- cmd=['shell', 'rm', '-r', path], |
- infra_step=True) |
- # Sometimes the removal fails silently. Verify that it worked. |
- if self.device_path_exists(path): |
- raise Exception('Failed to remove %s!' % path) # pragma: no cover |
- |
- def _create_device_dir(self, path): |
- """Create the directory on the device.""" |
- self._adb(name='mkdir %s' % self._bot_info.m.path.basename(path), |
- serial=self.serial, |
- cmd=['shell', 'mkdir', '-p', path], |
- infra_step=True) |
- |
- def copy_directory_contents_to_device(self, host_dir, device_dir): |
- """Like shutil.copytree(), but for copying to a connected device.""" |
- self._bot_info.run( |
- self._bot_info.m.step, |
- name='push %s' % self._bot_info.m.path.basename(host_dir), |
- cmd=[self.android_bin.join('adb_push_if_needed'), '--verbose', |
- '-s', self.serial, host_dir, device_dir], |
- env=self._default_env, |
- infra_step=True) |
- |
- def copy_directory_contents_to_host(self, device_dir, host_dir): |
- """Like shutil.copytree(), but for copying from a connected device.""" |
- self._bot_info.run( |
- self._bot_info.m.step, |
- name='pull %s' % self._bot_info.m.path.basename(device_dir), |
- cmd=[self.android_bin.join('adb_pull_if_needed'), '--verbose', |
- '-s', self.serial, device_dir, host_dir], |
- env=self._default_env, |
- infra_step=True) |
- |
- def copy_file_to_device(self, host_path, device_path): |
- """Like shutil.copyfile, but for copying to a connected device.""" |
- self._adb(name='push %s' % self._bot_info.m.path.basename(host_path), |
- serial=self.serial, |
- cmd=['push', host_path, device_path], |
- infra_step=True) |
- |
- def create_clean_device_dir(self, path): |
- """Like shutil.rmtree() + os.makedirs(), but on a connected device.""" |
- self._remove_device_dir(path) |
- self._create_device_dir(path) |
- |
- def install(self): |
- """Run device-specific installation steps.""" |
- if self._has_root: |
- self._adb(name='adb root', |
- serial=self.serial, |
- cmd=['root'], |
- infra_step=True) |
- # Wait for the device to reconnect. |
- self._bot_info.run( |
- self._bot_info.m.step, |
- name='wait', |
- cmd=['sleep', '10'], |
- infra_step=True) |
- self._adb.wait_for_device() |
- |
- # TODO(borenet): Set CPU scaling mode to 'performance'. |
- self._bot_info.run(self._bot_info.m.step, |
- name='kill skia', |
- cmd=[self.android_bin.join('android_kill_skia'), |
- '--verbose', '-s', self.serial], |
- env=self._default_env, |
- infra_step=True) |
- if self._has_root: |
- self._adb(name='stop shell', |
- serial=self.serial, |
- cmd=['shell', 'stop'], |
- infra_step=True) |
- |
- # Print out battery stats. |
- self._adb(name='starting battery stats', |
- serial=self.serial, |
- cmd=['shell', 'dumpsys', 'batteryproperties'], |
- infra_step=True) |
- |
- def cleanup_steps(self): |
- """Run any device-specific cleanup steps.""" |
- self._adb(name='final battery stats', |
- serial=self.serial, |
- cmd=['shell', 'dumpsys', 'batteryproperties'], |
- infra_step=True) |
- self._adb(name='reboot', |
- serial=self.serial, |
- cmd=['reboot'], |
- infra_step=True) |
- self._bot_info.run( |
- self._bot_info.m.step, |
- name='wait for reboot', |
- cmd=['sleep', '10'], |
- infra_step=True) |
- self._adb.wait_for_device() |
- |
- def read_file_on_device(self, path, *args, **kwargs): |
- """Read the given file.""" |
- return self._adb(name='read %s' % self._bot_info.m.path.basename(path), |
- serial=self.serial, |
- cmd=['shell', 'cat', path], |
- stdout=self._bot_info.m.raw_io.output(), |
- infra_step=True).stdout.rstrip() |
- |
- def remove_file_on_device(self, path, *args, **kwargs): |
- """Delete the given file.""" |
- return self._adb(name='rm %s' % self._bot_info.m.path.basename(path), |
- serial=self.serial, |
- cmd=['shell', 'rm', '-f', path], |
- infra_step=True, |
- *args, |
- **kwargs) |
- |
- def get_device_dirs(self): |
- """ Set the directories which will be used by the build steps.""" |
- device_scratch_dir = self._adb( |
- name='get EXTERNAL_STORAGE dir', |
- serial=self.serial, |
- cmd=['shell', 'echo', '$EXTERNAL_STORAGE'], |
- ) |
- prefix = self.device_path_join(device_scratch_dir, 'skiabot', 'skia_') |
- return default_flavor.DeviceDirs( |
- dm_dir=prefix + 'dm', |
- perf_data_dir=prefix + 'perf', |
- resource_dir=prefix + 'resources', |
- images_dir=prefix + 'images', |
- skp_dir=prefix + 'skp/skps', |
- tmp_dir=prefix + 'tmp_dir') |
- |