def check_profile_version(self, local_dir, serial=None): self.logger.info('Checking profile...') # get local version if os.path.isdir(local_dir): local_config = ConfigParser.ConfigParser() local_config.read(local_dir + os.sep + self._LOCAL_DIR_B2G + os.sep + self._FILE_PROFILE_INI) local_profile_path = local_config.get('Profile0', 'Path') local_config.read(local_dir + os.sep + self._LOCAL_DIR_B2G + os.sep + local_profile_path + os.sep + self._FILE_COMPATIBILITY_INI) version_of_backup = local_config.get('Compatibility', 'LastVersion') self.logger.info('The Version of Backup Profile: {}'.format(version_of_backup)) else: return False # get remote version tmp_dir = tempfile.mkdtemp(prefix='backup_restore_') if not AdbHelper.adb_pull(self._REMOTE_DIR_B2G + os.sep + self._FILE_PROFILE_INI, tmp_dir, serial=serial): self.logger.warning('Can not pull {2} from {0} to {1}'.format(self._REMOTE_DIR_B2G, tmp_dir, self._FILE_PROFILE_INI)) return False remote_config = ConfigParser.ConfigParser() remote_config.read(tmp_dir + os.sep + self._FILE_PROFILE_INI) remote_profile_path = local_config.get('Profile0', 'Path') if not AdbHelper.adb_pull(self._REMOTE_DIR_B2G + os.sep + remote_profile_path + os.sep + self._FILE_COMPATIBILITY_INI, tmp_dir, serial=serial): self.logger.warning('Can not pull {2} from {0} to {1}'.format(self._REMOTE_DIR_B2G, tmp_dir, self._FILE_COMPATIBILITY_INI)) return False remote_config.read(tmp_dir + os.sep + self._FILE_COMPATIBILITY_INI) version_of_device = remote_config.get('Compatibility', 'LastVersion') self.logger.info('The Version of Device Profile: {}'.format(version_of_device)) # compare version_of_backup_float = float(version_of_backup.split('_')[0]) version_of_device_float = float(version_of_device.split('_')[0]) if version_of_device_float >= version_of_backup_float: return True else: return False
def backup_profile(self, local_dir, serial=None): self.logger.info("Backing up profile...") # Backup Wifi wifi_dir = local_dir + os.sep + self._LOCAL_DIR_WIFI + os.sep wifi_file = local_dir + os.sep + self._LOCAL_FILE_WIFI os.makedirs(wifi_dir) self.logger.info("Backing up Wifi information...") if not AdbHelper.adb_pull(self._REMOTE_FILE_WIFI, wifi_file, serial=serial): self.logger.warning("If you don't have root permission, you cannot backup Wifi information.") # Backup profile b2g_mozilla_dir = local_dir + os.sep + self._LOCAL_DIR_B2G + os.sep os.makedirs(b2g_mozilla_dir) self.logger.info("Backing up {0} to {1} ...".format(self._REMOTE_DIR_B2G, b2g_mozilla_dir)) if not AdbHelper.adb_pull(self._REMOTE_DIR_B2G, b2g_mozilla_dir, serial=serial): self.logger.warning("Can not pull files from {0} to {1}".format(self._REMOTE_DIR_B2G, b2g_mozilla_dir)) # Backup data/local datalocal_dir = local_dir + os.sep + self._LOCAL_DIR_DATA + os.sep os.makedirs(datalocal_dir) self.logger.info("Backing up {0} to {1} ...".format(self._REMOTE_DIR_DATA, datalocal_dir)) if not AdbHelper.adb_pull(self._REMOTE_DIR_DATA, datalocal_dir, serial=serial): self.logger.warning("Can not pull files from {0} to {1}".format(self._REMOTE_DIR_DATA, datalocal_dir)) # Remove "marketplace" app and "gaiamobile.org" apps from webapps webapps_dir = datalocal_dir + self._LOCAL_DIR_DATA_APPS for root, dirs, files in os.walk(webapps_dir): if ( os.path.basename(root).startswith("marketplace") or os.path.basename(root).endswith("gaiamobile.org") or os.path.basename(root).endswith("allizom.org") ): self.logger.info("Removing Mozilla webapps: [{0}]".format(root)) shutil.rmtree(root) self.logger.info("Backup profile done.")
def backup_profile(self, local_dir, serial=None): self.logger.info('Backing up profile...') # Backup Wifi wifi_dir = local_dir + os.sep + self._LOCAL_DIR_WIFI + os.sep wifi_file = local_dir + os.sep + self._LOCAL_FILE_WIFI os.makedirs(wifi_dir) self.logger.info('Backing up Wifi information...') if not AdbHelper.adb_pull(self._REMOTE_FILE_WIFI, wifi_file, serial=serial): self.logger.warning('If you don\'t have root permission, you cannot backup Wifi information.') # Backup profile b2g_mozilla_dir = local_dir + os.sep + self._LOCAL_DIR_B2G + os.sep os.makedirs(b2g_mozilla_dir) self.logger.info('Backing up {0} to {1} ...'.format(self._REMOTE_DIR_B2G, b2g_mozilla_dir)) if not AdbHelper.adb_pull(self._REMOTE_DIR_B2G, b2g_mozilla_dir, serial=serial): self.logger.warning('Can not pull files from {0} to {1}'.format(self._REMOTE_DIR_B2G, b2g_mozilla_dir)) # Backup data/local datalocal_dir = local_dir + os.sep + self._LOCAL_DIR_DATA + os.sep os.makedirs(datalocal_dir) self.logger.info('Backing up {0} to {1} ...'.format(self._REMOTE_DIR_DATA, datalocal_dir)) if not AdbHelper.adb_pull(self._REMOTE_DIR_DATA, datalocal_dir, serial=serial): self.logger.warning('Can not pull files from {0} to {1}'.format(self._REMOTE_DIR_DATA, datalocal_dir)) # Remove "marketplace" app and "gaiamobile.org" apps from webapps webapps_dir = datalocal_dir + self._LOCAL_DIR_DATA_APPS for root, dirs, files in os.walk(webapps_dir): if (os.path.basename(root).startswith('marketplace') or os.path.basename(root).endswith('gaiamobile.org') or os.path.basename(root).endswith('allizom.org')): self.logger.info('Removing Mozilla webapps: [{0}]'.format(root)) shutil.rmtree(root) self.logger.info('Backup profile done.')
def check_profile_version(self, local_dir, serial=None): self.logger.info('Checking profile...') # get local version if os.path.isdir(local_dir): local_config = ConfigParser.ConfigParser() local_config.read(local_dir + os.sep + self._LOCAL_DIR_B2G + os.sep + self._FILE_PROFILE_INI) local_profile_path = local_config.get('Profile0', 'Path') local_config.read(local_dir + os.sep + self._LOCAL_DIR_B2G + os.sep + local_profile_path + os.sep + self._FILE_COMPATIBILITY_INI) version_of_backup = local_config.get('Compatibility', 'LastVersion') self.logger.info('The Version of Backup Profile: {}'.format(version_of_backup)) else: return False # get remote version tmp_dir = tempfile.mkdtemp(prefix='backup_restore_') if not AdbHelper.adb_pull(self._REMOTE_DIR_B2G + os.sep + self._FILE_PROFILE_INI, tmp_dir, serial=serial): self.logger.warning('Can not pull {2} from {0} to {1}'.format(self._REMOTE_DIR_B2G, tmp_dir, self._FILE_PROFILE_INI)) return False remote_config = ConfigParser.ConfigParser() remote_config.read(tmp_dir + os.sep + self._FILE_PROFILE_INI) remote_profile_path = remote_config.get('Profile0', 'Path') if not AdbHelper.adb_pull(self._REMOTE_DIR_B2G + os.sep + remote_profile_path + os.sep + self._FILE_COMPATIBILITY_INI, tmp_dir, serial=serial): self.logger.warning('Can not pull {2} from {0} to {1}'.format(self._REMOTE_DIR_B2G, tmp_dir, self._FILE_COMPATIBILITY_INI)) return False remote_config.read(tmp_dir + os.sep + self._FILE_COMPATIBILITY_INI) version_of_device = remote_config.get('Compatibility', 'LastVersion') self.logger.info('The Version of Device Profile: {}'.format(version_of_device)) # compare version_of_backup_float = float(version_of_backup.split('.')[0]) version_of_device_float = float(version_of_device.split('.')[0]) if version_of_device_float >= version_of_backup_float: return True else: return False
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 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 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
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