Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(37)

Side by Side Diff: build/android/pylib/uiautomator/test_runner.py

Issue 754433003: Update from https://crrev.com/305340 (Closed) Base URL: git@github.com:domokit/mojo.git@master
Patch Set: Created 6 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 # Copyright (c) 2013 The Chromium Authors. All rights reserved. 1 # Copyright (c) 2013 The Chromium Authors. All rights reserved.
2 # Use of this source code is governed by a BSD-style license that can be 2 # Use of this source code is governed by a BSD-style license that can be
3 # found in the LICENSE file. 3 # found in the LICENSE file.
4 4
5 """Class for running uiautomator tests on a single device.""" 5 """Class for running uiautomator tests on a single device."""
6 6
7 from pylib import constants 7 from pylib import constants
8 from pylib import flag_changer 8 from pylib import flag_changer
9 from pylib.device import intent 9 from pylib.device import intent
10 from pylib.instrumentation import test_options as instr_test_options 10 from pylib.instrumentation import test_options as instr_test_options
(...skipping 22 matching lines...) Expand all
33 test_options.test_data, 33 test_options.test_data,
34 test_options.save_perf_json, 34 test_options.save_perf_json,
35 test_options.screenshot_failures, 35 test_options.screenshot_failures,
36 wait_for_debugger=False, 36 wait_for_debugger=False,
37 coverage_dir=None, 37 coverage_dir=None,
38 test_apk=None, 38 test_apk=None,
39 test_apk_path=None, 39 test_apk_path=None,
40 test_apk_jar_path=None, 40 test_apk_jar_path=None,
41 test_runner=None, 41 test_runner=None,
42 test_support_apk_path=None, 42 test_support_apk_path=None,
43 device_flags=None) 43 device_flags=None,
44 isolate_file_path=None)
44 super(TestRunner, self).__init__(instrumentation_options, device, 45 super(TestRunner, self).__init__(instrumentation_options, device,
45 shard_index, test_pkg) 46 shard_index, test_pkg)
46 47
47 cmdline_file = constants.PACKAGE_INFO[test_options.package].cmdline_file 48 cmdline_file = constants.PACKAGE_INFO[test_options.package].cmdline_file
48 self.flags = None 49 self.flags = None
49 if cmdline_file: 50 if cmdline_file:
50 self.flags = flag_changer.FlagChanger(self.device, cmdline_file) 51 self.flags = flag_changer.FlagChanger(self.device, cmdline_file)
51 self._package = constants.PACKAGE_INFO[test_options.package].package 52 self._package = constants.PACKAGE_INFO[test_options.package].package
52 self._activity = constants.PACKAGE_INFO[test_options.package].activity 53 self._activity = constants.PACKAGE_INFO[test_options.package].activity
53 54
54 #override 55 #override
55 def InstallTestPackage(self): 56 def InstallTestPackage(self):
56 self.test_pkg.Install(self.device) 57 self.test_pkg.Install(self.device)
57 58
58 #override 59 #override
59 def PushDataDeps(self):
60 pass
61
62 #override
63 def _RunTest(self, test, timeout): 60 def _RunTest(self, test, timeout):
64 self.device.ClearApplicationState(self._package) 61 self.device.ClearApplicationState(self._package)
65 if self.flags: 62 if self.flags:
66 annotations = self.test_pkg.GetTestAnnotations(test) 63 annotations = self.test_pkg.GetTestAnnotations(test)
67 if ('FirstRunExperience' == annotations.get('Feature', None)): 64 if 'FirstRunExperience' == annotations.get('Feature', None):
68 self.flags.RemoveFlags(['--disable-fre']) 65 self.flags.RemoveFlags(['--disable-fre'])
69 else: 66 else:
70 self.flags.AddFlags(['--disable-fre']) 67 self.flags.AddFlags(['--disable-fre'])
71 self.device.StartActivity( 68 self.device.StartActivity(
72 intent.Intent(action='android.intent.action.MAIN', 69 intent.Intent(action='android.intent.action.MAIN',
73 activity=self._activity, 70 activity=self._activity,
74 package=self._package), 71 package=self._package),
75 blocking=True, 72 blocking=True,
76 force_stop=True) 73 force_stop=True)
77 cmd = ['uiautomator', 'runtest', 74 cmd = ['uiautomator', 'runtest',
78 self.test_pkg.UIAUTOMATOR_PATH + self.test_pkg.GetPackageName(), 75 self.test_pkg.UIAUTOMATOR_PATH + self.test_pkg.GetPackageName(),
79 '-e', 'class', test] 76 '-e', 'class', test]
80 return self.device.RunShellCommand(cmd, timeout=timeout, retries=0) 77 return self.device.RunShellCommand(cmd, timeout=timeout, retries=0)
81 78
82 #override 79 #override
83 def _GenerateTestResult(self, test, instr_statuses, start_ms, duration_ms): 80 def _GenerateTestResult(self, test, instr_statuses, start_ms, duration_ms):
84 # uiautomator emits its summary status with INSTRUMENTATION_STATUS_CODE, 81 # uiautomator emits its summary status with INSTRUMENTATION_STATUS_CODE,
85 # not INSTRUMENTATION_CODE, so we have to drop if off the list of statuses. 82 # not INSTRUMENTATION_CODE, so we have to drop if off the list of statuses.
86 return super(TestRunner, self)._GenerateTestResult( 83 return super(TestRunner, self)._GenerateTestResult(
87 test, instr_statuses[:-1], start_ms, duration_ms) 84 test, instr_statuses[:-1], start_ms, duration_ms)
OLDNEW
« no previous file with comments | « build/android/pylib/perf/surface_stats_collector.py ('k') | build/android/pylib/utils/host_path_finder.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698