1
0
mirror of https://github.com/ARM-software/workload-automation.git synced 2025-03-21 01:59:13 +00:00

Merge pull request #30 from jimboatarm/UXPERF-81

Add workload validate step to check dependencies
This commit is contained in:
jimboatarm 2016-05-26 12:43:05 +01:00
commit 5c194f4ba7
3 changed files with 51 additions and 32 deletions

View File

@ -20,6 +20,7 @@ import time
from wlauto import AndroidUiAutoBenchmark, Parameter from wlauto import AndroidUiAutoBenchmark, Parameter
from wlauto.exceptions import DeviceError from wlauto.exceptions import DeviceError
from wlauto.exceptions import NotFoundError
__version__ = '0.1.0' __version__ = '0.1.0'
@ -83,12 +84,17 @@ class Gmail(AndroidUiAutoBenchmark):
if not self.device.is_wifi_connected(): if not self.device.is_wifi_connected():
raise DeviceError('Wifi is not connected for device {}'.format(self.device.name)) raise DeviceError('Wifi is not connected for device {}'.format(self.device.name))
self.storage_dir = self.device.path.join(self.device.working_directory) # Check for workload dependencies before proceeding
jpeg_files = [entry for entry in os.listdir(self.dependencies_directory) if entry.endswith(".jpg")]
for file in os.listdir(self.dependencies_directory): if len(jpeg_files) < 5:
if file.endswith(".jpg"): raise NotFoundError("This workload requires a minimum of five {} files in {}".format('jpg',
self.device.push_file(os.path.join(self.dependencies_directory, file), self.dependencies_directory))
os.path.join(self.storage_dir, file), timeout=300) else:
for entry in jpeg_files:
self.device.push_file(os.path.join(self.dependencies_directory, entry),
os.path.join(self.device.working_directory, entry),
timeout=300)
# Force a re-index of the mediaserver cache to pick up new files # Force a re-index of the mediaserver cache to pick up new files
self.device.execute('am broadcast -a android.intent.action.MEDIA_MOUNTED -d file:///sdcard') self.device.execute('am broadcast -a android.intent.action.MEDIA_MOUNTED -d file:///sdcard')
@ -114,17 +120,17 @@ class Gmail(AndroidUiAutoBenchmark):
def teardown(self, context): def teardown(self, context):
super(Gmail, self).teardown(context) super(Gmail, self).teardown(context)
for file in self.device.listdir(self.device.working_directory): for entry in self.device.listdir(self.device.working_directory):
if file.endswith(".log"): if entry.endswith(".log"):
self.device.pull_file(os.path.join(self.device.working_directory, file), context.output_directory) self.device.pull_file(os.path.join(self.device.working_directory, entry), context.output_directory)
self.device.delete_file(os.path.join(self.device.working_directory, file)) self.device.delete_file(os.path.join(self.device.working_directory, entry))
def finalize(self, context): def finalize(self, context):
super(Gmail, self).finalize(context) super(Gmail, self).finalize(context)
for file in self.device.listdir(self.device.working_directory): for entry in self.device.listdir(self.device.working_directory):
if file.endswith(".jpg"): if entry.endswith(".jpg"):
self.device.delete_file(os.path.join(self.device.working_directory, file)) self.device.delete_file(os.path.join(self.device.working_directory, entry))
# Force a re-index of the mediaserver cache to pick up new files # Force a re-index of the mediaserver cache to pick up new files
self.device.execute('am broadcast -a android.intent.action.MEDIA_MOUNTED -d file:///sdcard') self.device.execute('am broadcast -a android.intent.action.MEDIA_MOUNTED -d file:///sdcard')

View File

@ -18,6 +18,7 @@ import re
from wlauto import AndroidUiAutoBenchmark, Parameter from wlauto import AndroidUiAutoBenchmark, Parameter
from wlauto.exceptions import DeviceError from wlauto.exceptions import DeviceError
from wlauto.exceptions import NotFoundError
__version__ = '0.1.0' __version__ = '0.1.0'
@ -65,7 +66,6 @@ class Googlephotos(AndroidUiAutoBenchmark):
] ]
instrumentation_log = ''.join([name, '_instrumentation.log']) instrumentation_log = ''.join([name, '_instrumentation.log'])
file_prefix = 'wa_test_'
def __init__(self, device, **kwargs): def __init__(self, device, **kwargs):
super(Googlephotos, self).__init__(device, **kwargs) super(Googlephotos, self).__init__(device, **kwargs)
@ -84,11 +84,16 @@ class Googlephotos(AndroidUiAutoBenchmark):
if not self.device.is_wifi_connected(): if not self.device.is_wifi_connected():
raise DeviceError('Wifi is not connected for device {}'.format(self.device.name)) raise DeviceError('Wifi is not connected for device {}'.format(self.device.name))
for entry in os.listdir(self.dependencies_directory): # Check for workload dependencies before proceeding
wa_file = ''.join([self.file_prefix, entry]) jpeg_files = [entry for entry in os.listdir(self.dependencies_directory) if entry.endswith(".jpg")]
if entry.endswith(".jpg"):
if len(jpeg_files) < 4:
raise NotFoundError("This workload requires a minimum of four {} files in {}".format('jpg',
self.dependencies_directory))
else:
for entry in jpeg_files:
self.device.push_file(os.path.join(self.dependencies_directory, entry), self.device.push_file(os.path.join(self.dependencies_directory, entry),
os.path.join(self.device.working_directory, wa_file), os.path.join(self.device.working_directory, entry),
timeout=300) timeout=300)
# Force a re-index of the mediaserver cache to pick up new files # Force a re-index of the mediaserver cache to pick up new files
@ -126,7 +131,7 @@ class Googlephotos(AndroidUiAutoBenchmark):
super(Googlephotos, self).finalize(context) super(Googlephotos, self).finalize(context)
for entry in self.device.listdir(self.device.working_directory): for entry in self.device.listdir(self.device.working_directory):
if entry.startswith(self.file_prefix) and entry.endswith(".jpg"): if entry.endswith(".jpg"):
self.device.delete_file(os.path.join(self.device.working_directory, entry)) self.device.delete_file(os.path.join(self.device.working_directory, entry))
# Force a re-index of the mediaserver cache to removed cached files # Force a re-index of the mediaserver cache to removed cached files

View File

@ -20,6 +20,7 @@ import time
from wlauto import AndroidUiAutoBenchmark, Parameter from wlauto import AndroidUiAutoBenchmark, Parameter
from wlauto.exceptions import DeviceError from wlauto.exceptions import DeviceError
from wlauto.exceptions import NotFoundError
__version__ = '0.1.0' __version__ = '0.1.0'
@ -86,16 +87,19 @@ class Reader(AndroidUiAutoBenchmark):
if not self.device.is_wifi_connected(): if not self.device.is_wifi_connected():
raise DeviceError('Wifi is not connected for device {}'.format(self.device.name)) raise DeviceError('Wifi is not connected for device {}'.format(self.device.name))
def setup(self, context):
super(Reader, self).setup(context)
self.reader_local_dir = self.device.path.join(self.device.external_storage_directory, self.reader_local_dir = self.device.path.join(self.device.external_storage_directory,
'Android/data/com.adobe.reader/files/') 'Android/data/com.adobe.reader/files/')
for file in os.listdir(self.dependencies_directory): # Check for workload dependencies before proceeding
if file.endswith(".pdf"): pdf_files = [entry for entry in os.listdir(self.dependencies_directory) if entry.endswith(".pdf")]
self.device.push_file(os.path.join(self.dependencies_directory, file),
os.path.join(self.reader_local_dir, file), timeout=300) if not len(pdf_files):
raise NotFoundError("Cannot find {} file(s) in {}".format('pdf', self.dependencies_directory))
else:
for entry in pdf_files:
self.device.push_file(os.path.join(self.dependencies_directory, entry),
os.path.join(self.reader_local_dir, entry),
timeout=300)
def update_result(self, context): def update_result(self, context):
super(Reader, self).update_result(context) super(Reader, self).update_result(context)
@ -117,11 +121,15 @@ class Reader(AndroidUiAutoBenchmark):
def teardown(self, context): def teardown(self, context):
super(Reader, self).teardown(context) super(Reader, self).teardown(context)
for file in self.device.listdir(self.reader_local_dir):
if file.endswith(".pdf"):
self.device.delete_file(os.path.join(self.reader_local_dir, file))
for file in self.device.listdir(self.device.working_directory): for entry in self.device.listdir(self.device.working_directory):
if file.endswith(".log"): if entry.endswith(".log"):
self.device.pull_file(os.path.join(self.device.working_directory, file), context.output_directory) self.device.pull_file(os.path.join(self.device.working_directory, entry), context.output_directory)
self.device.delete_file(os.path.join(self.device.working_directory, file)) self.device.delete_file(os.path.join(self.device.working_directory, entry))
def finalize(self, context):
super(Reader, self).finalize(context)
for entry in self.device.listdir(self.reader_local_dir):
if entry.endswith(".pdf"):
self.device.delete_file(os.path.join(self.reader_local_dir, entry))