1
0
mirror of https://github.com/ARM-software/workload-automation.git synced 2025-10-24 04:34:05 +01:00

logcat_parsing: Replace errors when decoding logcat output

Some devices print non standard characters to logcat. If an error
occurs when parsing the output, replace the offending character instead
of raising an error.
This commit is contained in:
Marc Bonnici
2020-04-02 17:33:48 +01:00
parent 2cd4bf7e31
commit dad0a28b5e
10 changed files with 11 additions and 11 deletions

View File

@@ -51,7 +51,7 @@ class LogcatEvent(object):
class LogcatParser(object): class LogcatParser(object):
def parse(self, filepath): def parse(self, filepath):
with open(filepath) as fh: with open(filepath, errors='replace') as fh:
for line in fh: for line in fh:
event = self.parse_line(line) event = self.parse_line(line)
if event: if event:

View File

@@ -50,7 +50,7 @@ class Aitutu(ApkUiautoWorkload):
super(Aitutu, self).update_output(context) super(Aitutu, self).update_output(context)
expected_results = len(self.regex_matches) expected_results = len(self.regex_matches)
logcat_file = context.get_artifact_path('logcat') logcat_file = context.get_artifact_path('logcat')
with open(logcat_file) as fh: with open(logcat_file, errors='replace') as fh:
for line in fh: for line in fh:
for regex in self.regex_matches: for regex in self.regex_matches:
match = regex.search(line) match = regex.search(line)

View File

@@ -43,7 +43,7 @@ class Androbench(ApkUiautoWorkload):
super(Androbench, self).update_output(context) super(Androbench, self).update_output(context)
expected_results = len(self.regex_matches) expected_results = len(self.regex_matches)
logcat_file = context.get_artifact_path('logcat') logcat_file = context.get_artifact_path('logcat')
with open(logcat_file) as fh: with open(logcat_file, errors='replace') as fh:
for line in fh: for line in fh:
for regex in self.regex_matches: for regex in self.regex_matches:
match = regex.search(line) match = regex.search(line)

View File

@@ -77,7 +77,7 @@ class Antutu(ApkUiautoWorkload):
#pylint: disable=no-self-use #pylint: disable=no-self-use
expected_results = len(regex_version) expected_results = len(regex_version)
logcat_file = context.get_artifact_path('logcat') logcat_file = context.get_artifact_path('logcat')
with open(logcat_file) as fh: with open(logcat_file, errors='replace') as fh:
for line in fh: for line in fh:
for regex in regex_version: for regex in regex_version:
match = regex.search(line) match = regex.search(line)

View File

@@ -51,7 +51,7 @@ class BenchmarkPi(ApkUiautoWorkload):
def update_output(self, context): def update_output(self, context):
super(BenchmarkPi, self).update_output(context) super(BenchmarkPi, self).update_output(context)
logcat_file = context.get_artifact_path('logcat') logcat_file = context.get_artifact_path('logcat')
with open(logcat_file) as fh: with open(logcat_file, errors='replace') as fh:
for line in fh: for line in fh:
match = self.regex.search(line) match = self.regex.search(line)
if match: if match:

View File

@@ -51,7 +51,7 @@ class Gfxbench(ApkUiautoWorkload):
super(Gfxbench, self).update_output(context) super(Gfxbench, self).update_output(context)
expected_results = len(self.regex_matches) expected_results = len(self.regex_matches)
logcat_file = context.get_artifact_path('logcat') logcat_file = context.get_artifact_path('logcat')
with open(logcat_file) as fh: with open(logcat_file, errors='replace') as fh:
for line in fh: for line in fh:
for regex in self.regex_matches: for regex in self.regex_matches:
match = regex.search(line) match = regex.search(line)

View File

@@ -153,7 +153,7 @@ class Jankbench(ApkWorkload):
def extract_metrics_from_logcat(self, context): def extract_metrics_from_logcat(self, context):
metric_names = ['mean', 'junk_p', 'std_dev', 'count_bad', 'count_junk'] metric_names = ['mean', 'junk_p', 'std_dev', 'count_bad', 'count_junk']
logcat_file = context.get_artifact_path('logcat') logcat_file = context.get_artifact_path('logcat')
with open(logcat_file) as fh: with open(logcat_file, errors='replace') as fh:
run_tests = copy(self.test_ids or self.valid_test_ids) run_tests = copy(self.test_ids or self.valid_test_ids)
current_iter = None current_iter = None
current_test = None current_test = None

View File

@@ -61,7 +61,7 @@ class Motionmark(UiautoWorkload):
super(Motionmark, self).update_output(context) super(Motionmark, self).update_output(context)
num_unprocessed_results = len(self.regex) num_unprocessed_results = len(self.regex)
logcat_file = context.get_artifact_path('logcat') logcat_file = context.get_artifact_path('logcat')
with open(logcat_file) as fh: with open(logcat_file, errors='replace') as fh:
for line in fh: for line in fh:
for regex in self.regex: for regex in self.regex:
match = regex.search(line) match = regex.search(line)

View File

@@ -20,6 +20,7 @@ from wa.framework.exception import ValidationError, WorkloadError
from wa.utils.types import list_of_strs from wa.utils.types import list_of_strs
from wa.utils.misc import unique from wa.utils.misc import unique
class Speedometer(ApkUiautoWorkload): class Speedometer(ApkUiautoWorkload):
name = 'speedometer' name = 'speedometer'
@@ -55,7 +56,7 @@ class Speedometer(ApkUiautoWorkload):
super(Speedometer, self).update_output(context) super(Speedometer, self).update_output(context)
result = None result = None
logcat_file = context.get_artifact_path('logcat') logcat_file = context.get_artifact_path('logcat')
with open(logcat_file) as fh: with open(logcat_file, errors='replace') as fh:
for line in fh: for line in fh:
match = self.regex.search(line) match = self.regex.search(line)
if match: if match:
@@ -65,4 +66,3 @@ class Speedometer(ApkUiautoWorkload):
context.add_metric('Speedometer Score', result, 'Runs per minute', lower_is_better=False) context.add_metric('Speedometer Score', result, 'Runs per minute', lower_is_better=False)
else: else:
raise WorkloadError("The Speedometer workload has failed. No score was obtainable.") raise WorkloadError("The Speedometer workload has failed. No score was obtainable.")

View File

@@ -145,7 +145,7 @@ class Vellamo(ApkUiautoWorkload):
def non_root_update_output(self, context): def non_root_update_output(self, context):
failed = [] failed = []
logcat_file = context.get_artifact_path('logcat') logcat_file = context.get_artifact_path('logcat')
with open(logcat_file) as fh: with open(logcat_file, errors='replace') as fh:
iteration_result_regex = re.compile("VELLAMO RESULT: (Browser|Metal|Multicore) (\d+)") iteration_result_regex = re.compile("VELLAMO RESULT: (Browser|Metal|Multicore) (\d+)")
for line in fh: for line in fh:
if 'VELLAMO ERROR:' in line: if 'VELLAMO ERROR:' in line: