| OLD | NEW | 
|---|
| 1 #!/usr/bin/env python | 1 #!/usr/bin/env python | 
| 2 # | 2 # | 
| 3 # Copyright (c) 2012 The Chromium Authors. All rights reserved. | 3 # Copyright (c) 2012 The Chromium Authors. All rights reserved. | 
| 4 # Use of this source code is governed by a BSD-style license that can be | 4 # Use of this source code is governed by a BSD-style license that can be | 
| 5 # found in the LICENSE file. | 5 # found in the LICENSE file. | 
| 6 | 6 | 
| 7 """Provides an interface to start and stop Android emulator. | 7 """Provides an interface to start and stop Android emulator. | 
| 8 | 8 | 
| 9 Assumes system environment ANDROID_NDK_ROOT has been set. | 9 Assumes system environment ANDROID_NDK_ROOT has been set. | 
| 10 | 10 | 
| (...skipping 178 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 189         os.unlink(full_name) | 189         os.unlink(full_name) | 
| 190 | 190 | 
| 191   def ConfirmLaunch(self, wait_for_boot=False): | 191   def ConfirmLaunch(self, wait_for_boot=False): | 
| 192     """Confirm the emulator launched properly. | 192     """Confirm the emulator launched properly. | 
| 193 | 193 | 
| 194     Loop on a wait-for-device with a very small timeout.  On each | 194     Loop on a wait-for-device with a very small timeout.  On each | 
| 195     timeout, check the emulator process is still alive. | 195     timeout, check the emulator process is still alive. | 
| 196     After confirming a wait-for-device can be successful, make sure | 196     After confirming a wait-for-device can be successful, make sure | 
| 197     it returns the right answer. | 197     it returns the right answer. | 
| 198     """ | 198     """ | 
| 199     a = android_commands.AndroidCommands(self.device) |  | 
| 200     seconds_waited = 0 | 199     seconds_waited = 0 | 
| 201     number_of_waits = 2  # Make sure we can wfd twice | 200     number_of_waits = 2  # Make sure we can wfd twice | 
| 202     adb_cmd = "adb -s %s %s" % (self.device, 'wait-for-device') | 201     adb_cmd = "adb -s %s %s" % (self.device, 'wait-for-device') | 
| 203     while seconds_waited < self._LAUNCH_TIMEOUT: | 202     while seconds_waited < self._LAUNCH_TIMEOUT: | 
| 204       try: | 203       try: | 
| 205         run_command.RunCommand(adb_cmd, | 204         run_command.RunCommand(adb_cmd, | 
| 206                                timeout_time=self._WAITFORDEVICE_TIMEOUT, | 205                                timeout_time=self._WAITFORDEVICE_TIMEOUT, | 
| 207                                retry_count=1) | 206                                retry_count=1) | 
| 208         number_of_waits -= 1 | 207         number_of_waits -= 1 | 
| 209         if not number_of_waits: | 208         if not number_of_waits: | 
| 210           break | 209           break | 
| 211       except errors.WaitForResponseTimedOutError as e: | 210       except errors.WaitForResponseTimedOutError as e: | 
| 212         seconds_waited += self._WAITFORDEVICE_TIMEOUT | 211         seconds_waited += self._WAITFORDEVICE_TIMEOUT | 
| 213         adb_cmd = "adb -s %s %s" % (self.device, 'kill-server') | 212         adb_cmd = "adb -s %s %s" % (self.device, 'kill-server') | 
| 214         run_command.RunCommand(adb_cmd) | 213         run_command.RunCommand(adb_cmd) | 
| 215       self.popen.poll() | 214       self.popen.poll() | 
| 216       if self.popen.returncode != None: | 215       if self.popen.returncode != None: | 
| 217         raise EmulatorLaunchException('EMULATOR DIED') | 216         raise EmulatorLaunchException('EMULATOR DIED') | 
| 218     if seconds_waited >= self._LAUNCH_TIMEOUT: | 217     if seconds_waited >= self._LAUNCH_TIMEOUT: | 
| 219       raise EmulatorLaunchException('TIMEOUT with wait-for-device') | 218       raise EmulatorLaunchException('TIMEOUT with wait-for-device') | 
| 220     logging.info('Seconds waited on wait-for-device: %d', seconds_waited) | 219     logging.info('Seconds waited on wait-for-device: %d', seconds_waited) | 
| 221     if wait_for_boot: | 220     if wait_for_boot: | 
| 222       # Now that we checked for obvious problems, wait for a boot complete. | 221       # Now that we checked for obvious problems, wait for a boot complete. | 
| 223       # Waiting for the package manager is sometimes problematic. | 222       # Waiting for the package manager is sometimes problematic. | 
| 224       a.Adb().SetTargetSerial(self.device) | 223       a = android_commands.AndroidCommands(self.device) | 
| 225       a.Adb().WaitForSystemBootCompleted(self._WAITFORBOOT_TIMEOUT) | 224       a.Adb().WaitForSystemBootCompleted(self._WAITFORBOOT_TIMEOUT) | 
| 226 | 225 | 
| 227   def Shutdown(self): | 226   def Shutdown(self): | 
| 228     """Shuts down the process started by launch.""" | 227     """Shuts down the process started by launch.""" | 
| 229     if self.popen: | 228     if self.popen: | 
| 230       self.popen.poll() | 229       self.popen.poll() | 
| 231       if self.popen.returncode == None: | 230       if self.popen.returncode == None: | 
| 232         self.popen.kill() | 231         self.popen.kill() | 
| 233       self.popen = None | 232       self.popen = None | 
| 234 | 233 | 
| 235   def _ShutdownOnSignal(self, signum, frame): | 234   def _ShutdownOnSignal(self, signum, frame): | 
| 236     logging.critical('emulator _ShutdownOnSignal') | 235     logging.critical('emulator _ShutdownOnSignal') | 
| 237     for sig in self._SIGNALS: | 236     for sig in self._SIGNALS: | 
| 238       signal.signal(sig, signal.SIG_DFL) | 237       signal.signal(sig, signal.SIG_DFL) | 
| 239     self.Shutdown() | 238     self.Shutdown() | 
| 240     raise KeyboardInterrupt  # print a stack | 239     raise KeyboardInterrupt  # print a stack | 
| 241 | 240 | 
| 242   def _InstallKillHandler(self): | 241   def _InstallKillHandler(self): | 
| 243     """Install a handler to kill the emulator when we exit unexpectedly.""" | 242     """Install a handler to kill the emulator when we exit unexpectedly.""" | 
| 244     for sig in self._SIGNALS: | 243     for sig in self._SIGNALS: | 
| 245       signal.signal(sig, self._ShutdownOnSignal) | 244       signal.signal(sig, self._ShutdownOnSignal) | 
| 246 | 245 | 
| 247 def main(argv): | 246 def main(argv): | 
| 248   Emulator(True).Launch(True) | 247   Emulator(True).Launch(True) | 
| 249 | 248 | 
| 250 | 249 | 
| 251 if __name__ == '__main__': | 250 if __name__ == '__main__': | 
| 252   main(sys.argv) | 251   main(sys.argv) | 
| OLD | NEW | 
|---|