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

Unified Diff: build/android/pylib/instrumentation/setup.py

Issue 18770008: [Android] Redesigns the sharder to allow replicated vs distributed tests (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Re-adds -f short form to gtest_filter switch Created 7 years, 5 months 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « build/android/pylib/instrumentation/dispatch.py ('k') | build/android/pylib/instrumentation/test_runner.py » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: build/android/pylib/instrumentation/setup.py
diff --git a/build/android/pylib/instrumentation/dispatch.py b/build/android/pylib/instrumentation/setup.py
similarity index 25%
rename from build/android/pylib/instrumentation/dispatch.py
rename to build/android/pylib/instrumentation/setup.py
index e4ca2805243c6edb7f02830ae28bd808256ef6df..3c35a3e404ee37a0ac0dc7c12975524fb365cc86 100644
--- a/build/android/pylib/instrumentation/dispatch.py
+++ b/build/android/pylib/instrumentation/setup.py
@@ -2,7 +2,7 @@
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.
-"""Dispatches the instrumentation tests."""
+"""Generates test runner factory and tests for instrumentation tests."""
import logging
import os
@@ -10,53 +10,48 @@ import os
from pylib import android_commands
from pylib import constants
from pylib.base import base_test_result
-from pylib.base import shard
from pylib.utils import report_results
import test_package
import test_runner
-def Dispatch(options):
- """Dispatches instrumentation tests onto connected device(s).
-
- If possible, this method will attempt to shard the tests to
- all connected devices. Otherwise, dispatch and run tests on one device.
+def Setup(test_apk_path, test_apk_jar_path, annotations, exclude_annotations,
+ test_filter, build_type, test_data, install_apk, save_perf_json,
+ screenshot_failures, tool, wait_for_debugger, disable_assertions,
+ push_deps, cleanup_test_files):
+ """Create and return the test runner factory and tests.
Args:
- options: Command line options.
+ test_apk_path: Path to the test apk file.
+ test_apk_jar_path: Path to the jar associated with the test apk.
+ annotations: Annotations for the tests.
+ exclude_annotations: Any annotations to exclude from running.
+ test_filter: Filter string for tests.
+ build_type: 'Release' or 'Debug'.
+ test_data: Location of the test data.
+ install_apk: Re-installs the apk if opted.
+ save_perf_json: Whether or not to save the JSON file from UI perf tests.
+ screenshot_failures: Take a screenshot for a test failure
+ tool: Name of the Valgrind tool.
+ wait_for_debugger: blocks until the debugger is connected.
+ disable_assertions: Whether to disable java assertions on the device.
+ push_deps: If True, push all dependencies to the device.
+ cleanup_test_files: Whether or not to cleanup test files on device.
Returns:
- A tuple of (base_test_result.TestRunResults object, exit code).
-
- Raises:
- Exception: when there are no attached devices.
+ A tuple of (TestRunnerFactory, tests).
"""
- test_pkg = test_package.TestPackage(options.test_apk_path,
- options.test_apk_jar_path)
- tests = test_pkg._GetAllMatchingTests(
- options.annotations, options.exclude_annotations, options.test_filter)
+ test_pkg = test_package.TestPackage(test_apk_path, test_apk_jar_path)
+ tests = test_pkg._GetAllMatchingTests(annotations, exclude_annotations,
+ test_filter)
if not tests:
logging.error('No instrumentation tests to run with current args.')
- return (base_test_result.TestRunResults(), constants.ERROR_EXIT_CODE)
-
- attached_devices = android_commands.GetAttachedDevices()
- if not attached_devices:
- raise Exception('There are no devices online.')
-
- if options.test_device:
- assert options.test_device in attached_devices
- attached_devices = [options.test_device]
-
- if len(attached_devices) > 1 and options.wait_for_debugger:
- logging.warning('Debugger can not be sharded, using first available device')
- attached_devices = attached_devices[:1]
def TestRunnerFactory(device, shard_index):
return test_runner.TestRunner(
- options, device, shard_index, test_pkg, [])
+ build_type, test_data, install_apk, save_perf_json, screenshot_failures,
+ tool, wait_for_debugger, disable_assertions, push_deps,
+ cleanup_test_files, device, shard_index, test_pkg, [])
- return shard.ShardAndRunTests(TestRunnerFactory, attached_devices, tests,
- options.build_type,
- test_timeout=None,
- num_retries=options.num_retries)
+ return (TestRunnerFactory, tests)
« no previous file with comments | « build/android/pylib/instrumentation/dispatch.py ('k') | build/android/pylib/instrumentation/test_runner.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698