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:
parent
164f207084
commit
dd61f99785
@ -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:
|
||||||
return asset
|
try:
|
||||||
|
ReventParser.check_revent_file(asset['path'])
|
||||||
|
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))
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user