# Copyright 2013-2015 ARM Limited # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. # import os import re import time from wlauto import AndroidBenchmark, Parameter class Nenamark(AndroidBenchmark): name = 'nenamark' description = """ NenaMark is an OpenGL-ES 2.0 graphics performance benchmark for Android devices. http://nena.se/nenamark_story From the website: The NenaMark2 benchmark scene averages about 45k triangles, with a span between 26k and 68k triangles. It averages 96 batches per frame and contains about 15 Mb of texture data (non-packed). """ package = 'se.nena.nenamark2' activity = 'se.nena.nenamark2.NenaMark2' parameters = [ Parameter('duration', kind=int, default=120, description=""" Number of seconds to wait before considering the benchmark finished """), ] regex = re.compile('.*NenaMark2.*Score.*?([0-9\.]*)fps') def run(self, context): time.sleep(5) # wait for nenamark menu to show up self.device.execute('input keyevent 23') time.sleep(self.duration) def update_result(self, context): super(Nenamark, self).update_result(context) with open(self.logcat_log) as fh: for line in fh: match = self.regex.search(line) if match: score = match.group(1) context.result.add_metric('nenamark score', score) break