summaryrefslogtreecommitdiff
path: root/andebench2014/vc.py
blob: b778db0821613ccd19254ff8530527eee47d1267 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
import re
import sys
import os
import time
from subprocess import call

from com.dtmilano.android.viewclient import ViewClient, ViewNotFoundException

kwargs1 = {'verbose': False, 'ignoresecuredevice': False}
device, serialno = ViewClient.connectToDeviceOrExit(**kwargs1)
kwargs2 = {'startviewserver': True, 'forceviewserveruse': False, 'autodump': False, 'ignoreuiautomatorkilled': True, 'compresseddump': False}
vc = ViewClient(device, serialno, **kwargs2)
vc.dump()

btn_start_on = vc.findViewByIdOrRaise("com.eembc.coremark:id/btn_start_on")
btn_start_on.touch()
finished = False
while(not finished):
    try:
        time.sleep(20)
        vc.dump()
        btn_close = vc.findViewById("com.eembc.coremark:id/btn_close")
        if btn_close:
            btn_close.touch()
            continue

        results = vc.findViewByIdOrRaise("com.eembc.coremark:id/cid")
        if not results.getText().find("Running") > 0:
            finished = True
            print "benchmark finished"
            result_re = re.compile("(?P<test_case_id>[a-zA-Z\s]+):\s(?P<measurement>\d+)", re.MULTILINE)
            search_results = result_re.finditer(results.getText())
            for result in search_results:
                test_case_id = result.group('test_case_id').strip()
                measurement = result.group('measurement').strip()
                print "%s=%s Iterations/sec" % (test_case_id, measurement)
                call(['lava-test-case', test_case_id, '--result', 'pass', '--measurement', measurement, '--units', 'Iterations/sec'])
    except ViewNotFoundException:
        pass
    except RuntimeError:
        pass
    except ValueError:
        pass