| Index: build/android/pylib/remote/device/remote_device_test_run.py | 
| diff --git a/build/android/pylib/remote/device/remote_device_test_run.py b/build/android/pylib/remote/device/remote_device_test_run.py | 
| index 7aa91aebc751c3220bc71e718016364e14c9f718..60a066442cb1837f691d71acf760f0074cbaed6c 100644 | 
| --- a/build/android/pylib/remote/device/remote_device_test_run.py | 
| +++ b/build/android/pylib/remote/device/remote_device_test_run.py | 
| @@ -29,6 +29,8 @@ class RemoteDeviceTestRun(test_run.TestRun): | 
| COMPLETE = 'complete' | 
| HEARTBEAT_INTERVAL = 300 | 
|  | 
| +  _RESULTS_FILE = 'appurify_results/result.txt' | 
| + | 
| def __init__(self, env, test_instance): | 
| """Constructor. | 
|  | 
| @@ -173,7 +175,7 @@ class RemoteDeviceTestRun(test_run.TestRun): | 
| """Download the test results from remote device service. | 
|  | 
| Args: | 
| -      results_path: path to download results to. | 
| +      results_path: Path to download appurify results zipfile. | 
| """ | 
| if results_path: | 
| logging.info('Downloading results to %s.' % results_path) | 
| @@ -184,6 +186,21 @@ class RemoteDeviceTestRun(test_run.TestRun): | 
| appurify_sanitized.utils.wget(self._results['results']['url'], | 
| results_path) | 
|  | 
| +  def _GetRawTestOutput(self): | 
| +    """Returns the test output.""" | 
| +    # TODO(mikecase): Remove getting results from zip when b/18981674 is fixed. | 
| +    results_zipfile = self._env.results_path | 
| +    if results_zipfile and os.path.exists(results_zipfile): | 
| +      with zipfile.ZipFile(results_zipfile) as z: | 
| +        with z.open(self._RESULTS_FILE, 'r') as r: | 
| +          return r.read() | 
| +    else: | 
| +      logging.warning( | 
| +          'If the test output is too long, some test results may get cut off.') | 
| +      logging.warning( | 
| +          'Use the --results-path option to ensure you get the full results.') | 
| +      return self._results['results']['output'] | 
| + | 
| def _GetTestStatus(self, test_run_id): | 
| """Checks the state of the test, and sets self._results | 
|  | 
| @@ -201,7 +218,7 @@ class RemoteDeviceTestRun(test_run.TestRun): | 
| return self._results['status'] | 
|  | 
| def _AmInstrumentTestSetup(self, app_path, test_path, runner_package, | 
| -                             environment_variables): | 
| +                             environment_variables, extra_apks=None): | 
| config = {'runner': runner_package} | 
| if environment_variables: | 
| config['environment_vars'] = ','.join( | 
| @@ -213,6 +230,7 @@ class RemoteDeviceTestRun(test_run.TestRun): | 
| if data_deps: | 
| with tempfile.NamedTemporaryFile(suffix='.zip') as test_with_deps: | 
| sdcard_files = [] | 
| +        additional_apks = [] | 
| host_test = os.path.basename(test_path) | 
| with zipfile.ZipFile(test_with_deps.name, 'w') as zip_file: | 
| zip_file.write(test_path, host_test, zipfile.ZIP_DEFLATED) | 
| @@ -223,8 +241,14 @@ class RemoteDeviceTestRun(test_run.TestRun): | 
| else: | 
| zip_utils.WriteToZipFile(zip_file, h, os.path.basename(h)) | 
| sdcard_files.append(os.path.basename(h)) | 
| +          for a in extra_apks or (): | 
| +            zip_utils.WriteToZipFile(zip_file, a, os.path.basename(a)); | 
| +            additional_apks.append(os.path.basename(a)) | 
| + | 
| config['sdcard_files'] = ','.join(sdcard_files) | 
| config['host_test'] = host_test | 
| +        if additional_apks: | 
| +          config['additional_apks'] = ','.join(additional_apks) | 
| self._test_id = self._UploadTestToDevice( | 
| 'robotium', test_with_deps.name, app_id=self._app_id) | 
| else: | 
| @@ -238,7 +262,8 @@ class RemoteDeviceTestRun(test_run.TestRun): | 
|  | 
| def _UploadAppToDevice(self, app_path): | 
| """Upload app to device.""" | 
| -    logging.info('Uploading %s to remote service.', app_path) | 
| +    logging.info('Uploading %s to remote service as %s.', app_path, | 
| +                 self._test_instance.suite) | 
| with open(app_path, 'rb') as apk_src: | 
| with appurify_sanitized.SanitizeLogging(self._env.verbose_count, | 
| logging.WARNING): | 
| @@ -297,4 +322,4 @@ class RemoteDeviceTestRun(test_run.TestRun): | 
| config_response = appurify_sanitized.api.config_upload( | 
| self._env.token, config, self._test_id) | 
| remote_device_helper.TestHttpResponse( | 
| -          config_response, 'Unable to upload test config.') | 
| +          config_response, 'Unable to upload test config.') | 
|  |