1
0
mirror of https://github.com/ARM-software/workload-automation.git synced 2025-01-19 12:24:32 +00:00

revent: Updated resource getters to check if a file is actually a recording

This commit is contained in:
Sebastian Goscik 2016-07-19 16:14:19 +01:00
parent 164f207084
commit dd61f99785

View File

@ -33,6 +33,7 @@ from wlauto.exceptions import ResourceError
from wlauto.utils.android import ApkInfo from wlauto.utils.android import ApkInfo
from wlauto.utils.misc import ensure_directory_exists as _d, ensure_file_directory_exists as _f, sha256, urljoin from wlauto.utils.misc import ensure_directory_exists as _d, ensure_file_directory_exists as _f, sha256, urljoin
from wlauto.utils.types import boolean from wlauto.utils.types import boolean
from wlauto.utils.revent import ReventParser
logging.getLogger("requests").setLevel(logging.WARNING) logging.getLogger("requests").setLevel(logging.WARNING)
@ -98,7 +99,12 @@ class ReventGetter(ResourceGetter):
location = _d(os.path.join(self.get_base_location(resource), 'revent_files')) location = _d(os.path.join(self.get_base_location(resource), 'revent_files'))
for candidate in os.listdir(location): for candidate in os.listdir(location):
if candidate.lower() == filename.lower(): if candidate.lower() == filename.lower():
return os.path.join(location, candidate) path = os.path.join(location, candidate)
try:
ReventParser.check_revent_file(path)
return path
except ValueError as e:
self.logger.warning(e.message)
class PackageApkGetter(PackageFileGetter): class PackageApkGetter(PackageFileGetter):
@ -430,7 +436,11 @@ class HttpGetter(ResourceGetter):
for asset in assets: for asset in assets:
pathname = os.path.basename(asset['path']).lower() pathname = os.path.basename(asset['path']).lower()
if pathname == filename: if pathname == filename:
try:
ReventParser.check_revent_file(asset['path'])
return asset return asset
except ValueError as e:
self.logger.warning(e.message)
else: # file else: # file
for asset in assets: for asset in assets:
if asset['path'].lower() == resource.path.lower(): if asset['path'].lower() == resource.path.lower():
@ -514,14 +524,22 @@ class RemoteFilerGetter(ResourceGetter):
# There tends to be some confusion as to where revent files should # There tends to be some confusion as to where revent files should
# be placed. This looks both in the extension's directory, and in # be placed. This looks both in the extension's directory, and in
# 'revent_files' subdirectory under it, if it exists. # 'revent_files' subdirectory under it, if it exists.
path = None
if os.path.isdir(alternate_location): if os.path.isdir(alternate_location):
for candidate in os.listdir(alternate_location): for candidate in os.listdir(alternate_location):
if candidate.lower() == filename.lower(): if candidate.lower() == filename.lower():
return os.path.join(alternate_location, candidate) path = os.path.join(alternate_location, candidate)
if os.path.isdir(location): if os.path.isdir(location):
for candidate in os.listdir(location): for candidate in os.listdir(location):
if candidate.lower() == filename.lower(): if candidate.lower() == filename.lower():
return os.path.join(location, candidate) path = os.path.join(location, candidate)
if path:
try:
ReventParser.check_revent_file(path)
return path
except ValueError as e:
self.logger.warning(e.message)
else: else:
raise ValueError('Unexpected resource type: {}'.format(resource.name)) raise ValueError('Unexpected resource type: {}'.format(resource.name))