def backup_sdcard(self, local_dir, serial=None): self.logger.info('Backing up SD card...') # try to get the /sdcard folder on device output = AdbHelper.adb_shell('ls -d {0}; echo $?'.format( self._REMOTE_DIR_SDCARD), serial=serial) output_list = [ item for item in re.split(r'\n+', re.sub(r'\r+', '', output)) if item ] ret_code = output_list[-1] output_list.remove(output_list[-1]) ret_msg = '\n'.join(output_list) if ret_code == '0': target_dir = local_dir + os.sep + self._LOCAL_DIR_SDCARD + os.sep os.makedirs(target_dir) self.logger.info('Backup: {0} to {1}'.format( self._REMOTE_DIR_SDCARD, target_dir)) if not AdbHelper.adb_pull( self._REMOTE_DIR_SDCARD, target_dir, serial=serial): self.logger.warning( 'Can not pull files from {0} to {1}'.format( self._REMOTE_DIR_SDCARD, target_dir)) else: self.logger.info(ret_msg) self.logger.info('Backup SD card done.')
def restore_profile(self, local_dir, serial=None): self.logger.info("Restoring profile...") if os.path.isdir(local_dir): # Restore Wifi wifi_file = local_dir + os.sep + self._LOCAL_FILE_WIFI if os.path.isfile(wifi_file): self.logger.info("Restoring Wifi information...") if not AdbHelper.adb_push(wifi_file, self._REMOTE_FILE_WIFI, serial=serial): self.logger.warning("If you don't have root permission, you cannot restore Wifi information.") AdbHelper.adb_shell("chown {0} {1}".format(self._REMOTE_FILE_WIFI_OWNER, self._REMOTE_FILE_WIFI)) # Restore profile b2g_mozilla_dir = local_dir + os.sep + self._LOCAL_DIR_B2G if os.path.isdir(b2g_mozilla_dir): self.logger.info("Restore from {0} to {1} ...".format(b2g_mozilla_dir, self._REMOTE_DIR_B2G)) AdbHelper.adb_shell("rm -r {0}".format(self._REMOTE_DIR_B2G)) if not AdbHelper.adb_push(b2g_mozilla_dir, self._REMOTE_DIR_B2G, serial=serial): self.logger.warning( "Can not push files from {0} to {1}".format(b2g_mozilla_dir, self._REMOTE_DIR_B2G) ) # Restore data/local datalocal_dir = local_dir + os.sep + self._LOCAL_DIR_DATA if os.path.isdir(datalocal_dir): self.logger.info("Restore from {0} to {1} ...".format(datalocal_dir, self._REMOTE_DIR_DATA)) AdbHelper.adb_shell("rm -r {0}".format(self._REMOTE_DIR_DATA)) if not AdbHelper.adb_push(datalocal_dir, self._REMOTE_DIR_DATA, serial=serial): self.logger.warning( "Can not push files from {0} to {1}".format(datalocal_dir, self._REMOTE_DIR_DATA) ) self.logger.info("Restore profile done.") else: self.logger.info("{0}: No such file or directory".format(local_dir)) return
def restore_profile(self, local_dir, serial=None): self.logger.info('Restoring profile...') if os.path.isdir(local_dir): # Restore Wifi wifi_file = local_dir + os.sep + self._LOCAL_FILE_WIFI if os.path.isfile(wifi_file): self.logger.info('Restoring Wifi information...') if not AdbHelper.adb_push(wifi_file, self._REMOTE_FILE_WIFI, serial=serial): self.logger.warning('If you don\'t have root permission, you cannot restore Wifi information.') AdbHelper.adb_shell('chown {0} {1}'.format(self._REMOTE_FILE_WIFI_OWNER, self._REMOTE_FILE_WIFI)) # Restore profile b2g_mozilla_dir = local_dir + os.sep + self._LOCAL_DIR_B2G if os.path.isdir(b2g_mozilla_dir): self.logger.info('Restore from {0} to {1} ...'.format(b2g_mozilla_dir, self._REMOTE_DIR_B2G)) AdbHelper.adb_shell('rm -r {0}'.format(self._REMOTE_DIR_B2G)) if not AdbHelper.adb_push(b2g_mozilla_dir, self._REMOTE_DIR_B2G, serial=serial): self.logger.warning('Can not push files from {0} to {1}'.format(b2g_mozilla_dir, self._REMOTE_DIR_B2G)) # Restore data/local datalocal_dir = local_dir + os.sep + self._LOCAL_DIR_DATA if os.path.isdir(datalocal_dir): self.logger.info('Restore from {0} to {1} ...'.format(datalocal_dir, self._REMOTE_DIR_DATA)) AdbHelper.adb_shell('rm -r {0}'.format(self._REMOTE_DIR_DATA)) if not AdbHelper.adb_push(datalocal_dir, self._REMOTE_DIR_DATA, serial=serial): self.logger.warning('Can not push files from {0} to {1}'.format(datalocal_dir, self._REMOTE_DIR_DATA)) self.logger.info('Restore profile done.') else: self.logger.info('{0}: No such file or directory'.format(local_dir)) return
def backup_sdcard(self, local_dir, serial=None): self.logger.info("Backing up SD card...") # try to get the /sdcard folder on device output = AdbHelper.adb_shell("ls -d {0}; echo $?".format(self._REMOTE_DIR_SDCARD), serial=serial) output_list = [item for item in re.split(r"\n+", re.sub(r"\r+", "", output)) if item] ret_code = output_list[-1] output_list.remove(output_list[-1]) ret_msg = "\n".join(output_list) if ret_code == "0": target_dir = local_dir + os.sep + self._LOCAL_DIR_SDCARD + os.sep os.makedirs(target_dir) self.logger.info("Backup: {0} to {1}".format(self._REMOTE_DIR_SDCARD, target_dir)) if not AdbHelper.adb_pull(self._REMOTE_DIR_SDCARD, target_dir, serial=serial): self.logger.warning("Can not pull files from {0} to {1}".format(self._REMOTE_DIR_SDCARD, target_dir)) else: self.logger.info(ret_msg) self.logger.info("Backup SD card done.")
def start_b2g(self, serial=None): self.logger.info("Start B2G.") output = AdbHelper.adb_shell("start b2g", serial=serial)
def get_device_info(self, serial=None): try: tmp_dir = tempfile.mkdtemp(prefix='checkversions_') # pull data from device if not AdbHelper.adb_pull( '/system/b2g/omni.ja', tmp_dir, serial=serial): print 'Error pulling Gecko file.' if not AdbHelper.adb_pull( '/data/local/webapps/settings.gaiamobile.org/application.zip', tmp_dir, serial=serial): if not AdbHelper.adb_pull( '/system/b2g/webapps/settings.gaiamobile.org/application.zip', tmp_dir, serial=serial): print 'Error pulling Gaia file.' if not AdbHelper.adb_pull( '/system/b2g/application.ini', tmp_dir, serial=serial): print 'Error pulling application.ini file.' # get Gaia info gaia_rev = 'n/a' gaia_date = 'n/a' application_zip_file = tmp_dir + os.sep + 'application.zip' if os.path.isfile(application_zip_file): f = open(application_zip_file, 'rb') z = zipfile.ZipFile(f) z.extract('resources/gaia_commit.txt', tmp_dir) f.close() else: print 'Can not find application.zip file.' gaiacommit_file = tmp_dir + os.sep + 'resources/gaia_commit.txt' if os.path.isfile(gaiacommit_file): f = open(gaiacommit_file, "r") gaia_rev = re.sub(r'\n+', '', f.readline()) gaia_date_sec_from_epoch = re.sub(r'\n+', '', f.readline()) f.close() gaia_date = datetime.utcfromtimestamp( int(gaia_date_sec_from_epoch)).strftime( '%Y-%m-%d %H:%M:%S') else: print 'Can not get gaia_commit.txt file from application.zip file.' # deoptimize omni.ja for Gecko info gecko_rev = 'n/a' if os.path.isfile(tmp_dir + os.sep + 'omni.ja'): deopt_dir = tmp_dir + os.sep + 'deopt' deopt_file = deopt_dir + os.sep + 'omni.ja' deopt_exec = tmp_dir + os.sep + 'optimizejars.py' os.makedirs(deopt_dir) shutil.copyfile('./optimizejars.py', deopt_exec) cmd = 'python %s --deoptimize %s %s %s' % (deopt_exec, tmp_dir, tmp_dir, deopt_dir) p = subprocess.Popen(cmd, shell=True, stdout=subprocess.PIPE, stderr=subprocess.STDOUT) output = p.communicate()[0] # unzip omni.ja to get Gecko info if os.path.isfile(deopt_file): f = open(deopt_file, 'rb') z = zipfile.ZipFile(f) z.extract('chrome/toolkit/content/global/buildconfig.html', tmp_dir) f.close() else: print 'Can not deoptimize omni.ja file.' gecko_rev = 'n/a' # get Gecko info from buildconfig.html file buildconfig_file = tmp_dir + os.sep + 'chrome/toolkit/content/global/buildconfig.html' if os.path.isfile(buildconfig_file): for line in open(buildconfig_file, "r"): if re.search(r'Built from', line): ret = re.findall(r'>(.*?)<', line) gecko_rev = ret[1] break else: print 'Can not get buildconfig.html file from omni.ja file.' else: print 'Can not find omni.ja file.' # get Gecko version, and B2G BuildID from application.ini file if os.path.isfile(tmp_dir + os.sep + 'application.ini'): for line in open(tmp_dir + os.sep + 'application.ini', "r"): if re.search(r'^\s*BuildID', line): ret = re.findall(r'.*?=(.*)', line) build_id = ret[0] if re.search(r'^\s*Version', line): ret = re.findall(r'.*?=(.*)', line) version = ret[0] else: build_id = 'n/a' version = 'n/a' # get device information by getprop command device_name = re.sub( r'\r+|\n+', '', AdbHelper.adb_shell('getprop ro.product.device', serial=serial)) firmware_release = re.sub( r'\r+|\n+', '', AdbHelper.adb_shell('getprop ro.build.version.release', serial=serial)) firmware_incremental = re.sub( r'\r+|\n+', '', AdbHelper.adb_shell('getprop ro.build.version.incremental', serial=serial)) firmware_date = re.sub( r'\r+|\n+', '', AdbHelper.adb_shell('getprop ro.build.date', serial=serial)) firmware_bootloader = re.sub( r'\r+|\n+', '', AdbHelper.adb_shell('getprop ro.boot.bootloader', serial=serial)) # prepare the return information device_info = {} device_info['Serial'] = serial device_info['Build ID'] = build_id device_info['Gaia Revision'] = gaia_rev device_info['Gaia Date'] = gaia_date device_info['Gecko Revision'] = gecko_rev device_info['Gecko Version'] = version device_info['Device Name'] = device_name device_info['Firmware(Release)'] = firmware_release device_info['Firmware(Incremental)'] = firmware_incremental device_info['Firmware Date'] = firmware_date device_info['Bootloader'] = firmware_bootloader finally: shutil.rmtree(tmp_dir) return device_info
sock.connect(server_address) data = sock.recv(1024).strip() if data <> "<< Control Server Connected >>": print "Successfully connected to the control server.\n" sys.exit() try: # Send data adb_devices = AdbHelper.adb_devices() for device in adb_devices.items(): message = "" # Check for device type if device[1] == "device": device_type = re.sub(r'\r+|\n+', '', AdbHelper.adb_shell('getprop ro.product.device', serial=device[0])) else: device_type = "unknown" # Check for device build if device[1] == "device": device_build = re.sub(r'\r+|\n+', '', AdbHelper.adb_shell('getprop ro.build.version.incremental', serial=device[0])) else: device_build = "unknown" # Check for device status if device[1] == "device": if os.path.isfile("/tmp/LOCKS/" + device[0] + ".lock"): device_avail = "locked" else: device_avial = "available"
def start_b2g(self, serial=None): self.logger.info('Start B2G.') output = AdbHelper.adb_shell('start b2g', serial=serial)
def get_device_info(self, serial=None): try: tmp_dir = tempfile.mkdtemp(prefix='checkversions_') # pull data from device if not AdbHelper.adb_pull('/system/b2g/omni.ja', tmp_dir, serial=serial): print 'Error pulling Gecko file.' if not AdbHelper.adb_pull('/data/local/webapps/settings.gaiamobile.org/application.zip', tmp_dir, serial=serial): if not AdbHelper.adb_pull('/system/b2g/webapps/settings.gaiamobile.org/application.zip', tmp_dir, serial=serial): print 'Error pulling Gaia file.' if not AdbHelper.adb_pull('/system/b2g/application.ini', tmp_dir, serial=serial): print 'Error pulling application.ini file.' # get Gaia info gaia_rev = 'n/a' gaia_date = 'n/a' application_zip_file = tmp_dir + os.sep + 'application.zip' if os.path.isfile(application_zip_file): f = open(application_zip_file, 'rb') z = zipfile.ZipFile(f) z.extract('resources/gaia_commit.txt', tmp_dir) f.close() else: print 'Can not find application.zip file.' gaiacommit_file = tmp_dir + os.sep + 'resources/gaia_commit.txt' if os.path.isfile(gaiacommit_file): f = open(gaiacommit_file, "r") gaia_rev = re.sub(r'\n+', '', f.readline()) gaia_date_sec_from_epoch = re.sub(r'\n+', '', f.readline()) f.close() gaia_date = datetime.utcfromtimestamp(int(gaia_date_sec_from_epoch)).strftime('%Y-%m-%d %H:%M:%S') else: print 'Can not get gaia_commit.txt file from application.zip file.' # deoptimize omni.ja for Gecko info gecko_rev = 'n/a' if os.path.isfile(tmp_dir + os.sep + 'omni.ja'): deopt_dir = tmp_dir + os.sep + 'deopt' deopt_file = deopt_dir + os.sep + 'omni.ja' deopt_exec = tmp_dir + os.sep + 'optimizejars.py' os.makedirs(deopt_dir) shutil.copyfile('./optimizejars.py', deopt_exec) cmd = 'python %s --deoptimize %s %s %s' % (deopt_exec, tmp_dir, tmp_dir, deopt_dir) p = subprocess.Popen(cmd, shell=True, stdout=subprocess.PIPE, stderr=subprocess.STDOUT) output = p.communicate()[0] # unzip omni.ja to get Gecko info if os.path.isfile(deopt_file): f = open(deopt_file, 'rb') z = zipfile.ZipFile(f) z.extract('chrome/toolkit/content/global/buildconfig.html', tmp_dir) f.close() else: print 'Can not deoptimize omni.ja file.' gecko_rev = 'n/a' # get Gecko info from buildconfig.html file buildconfig_file = tmp_dir + os.sep + 'chrome/toolkit/content/global/buildconfig.html' if os.path.isfile(buildconfig_file): for line in open(buildconfig_file, "r"): if re.search(r'Built from', line): ret = re.findall(r'>(.*?)<', line) gecko_rev = ret[1] break else: print 'Can not get buildconfig.html file from omni.ja file.' else: print 'Can not find omni.ja file.' # get Gecko version, and B2G BuildID from application.ini file if os.path.isfile(tmp_dir + os.sep + 'application.ini'): for line in open(tmp_dir + os.sep + 'application.ini', "r"): if re.search(r'^\s*BuildID', line): ret = re.findall(r'.*?=(.*)', line) build_id = ret[0] if re.search(r'^\s*Version', line): ret = re.findall(r'.*?=(.*)', line) version = ret[0] else: build_id = 'n/a' version = 'n/a' # get device information by getprop command device_name = re.sub(r'\r+|\n+', '', AdbHelper.adb_shell('getprop ro.product.device', serial=serial)) firmware_release = re.sub(r'\r+|\n+', '', AdbHelper.adb_shell('getprop ro.build.version.release', serial=serial)) firmware_incremental = re.sub(r'\r+|\n+', '', AdbHelper.adb_shell('getprop ro.build.version.incremental', serial=serial)) firmware_date = re.sub(r'\r+|\n+', '', AdbHelper.adb_shell('getprop ro.build.date', serial=serial)) firmware_bootloader = re.sub(r'\r+|\n+', '', AdbHelper.adb_shell('getprop ro.boot.bootloader', serial=serial)) # prepare the return information device_info = {} device_info['Serial'] = serial device_info['Build ID'] = build_id device_info['Gaia Revision'] = gaia_rev device_info['Gaia Date'] = gaia_date device_info['Gecko Revision'] = gecko_rev device_info['Gecko Version'] = version device_info['Device Name'] = device_name device_info['Firmware(Release)'] = firmware_release device_info['Firmware(Incremental)'] = firmware_incremental device_info['Firmware Date'] = firmware_date device_info['Bootloader'] = firmware_bootloader finally: shutil.rmtree(tmp_dir) return device_info