• Home
  • History
  • Annotate
Name Date Size #Lines LOC

..--

annotations-src/android/ravenwood/annotation/15-Dec-2024-36598

bivalenttest/15-Dec-2024-588342

coretest/15-Dec-2024-8146

framework-src/android/ravenwood/example/15-Dec-2024-7030

junit-flag-src/android/platform/test/flag/junit/15-Dec-2024-5521

junit-impl-src/android/platform/test/ravenwood/15-Dec-2024-1,3891,013

junit-src/android/platform/test/15-Dec-2024-969453

junit-stub-src/android/platform/test/ravenwood/15-Dec-2024-4317

minimum-test/15-Dec-2024-8052

mockito/15-Dec-2024-285164

runtime-common-device-src/com/android/ravenwood/common/divergence/15-Dec-2024-308

runtime-common-ravenwood-src/com/android/ravenwood/common/divergence/15-Dec-2024-308

runtime-common-src/com/android/ravenwood/common/15-Dec-2024-477261

runtime-helper-src/15-Dec-2024-4,0572,636

runtime-jni/15-Dec-2024-881789

runtime-test/15-Dec-2024-592487

scripts/15-Dec-2024-486247

services-test/15-Dec-2024-161102

texts/15-Dec-2024-463408

Android.bpD15-Dec-20247.1 KiB279253

OWNERSD15-Dec-2024230 96

README.mdD15-Dec-20242.9 KiB2919

TEST_MAPPINGD15-Dec-20241.3 KiB6463

api-maintainers.mdD15-Dec-20244.9 KiB9571

test-authors.mdD15-Dec-20249.5 KiB233171

README.md

1# Ravenwood
2
3Ravenwood is an officially-supported lightweight unit testing environment for Android platform code that runs on the host.
4
5Ravenwood’s focus on Android platform use-cases, improved maintainability, and device consistency distinguishes it from Robolectric, which remains a popular choice for app testing.
6
7## Background
8
9Executing tests on a typical Android device has substantial overhead, such as flashing the build, waiting for the boot to complete, and retrying tests that fail due to general flakiness.
10
11In contrast, defining a lightweight unit testing environment mitigates these issues by running directly from build artifacts (no flashing required), runs immediately (no booting required), and runs in an isolated environment (less flakiness).
12
13## Guiding principles
14Here’s a summary of the guiding principles for Ravenwood, aimed at addressing Robolectric design concerns and better supporting Android platform developers:
15
16* **API support for Ravenwood is opt-in.**  Teams that own APIs decide exactly what, and how, they support their API functionality being available to tests.  When an API hasn’t opted-in, the API signatures remain available for tests to compile against and/or mock, but they throw when called under a Ravenwood environment.
17    * _Contrasted with Robolectric which attempts to run API implementations as-is, causing maintenance pains as teams maintain or redesign their API internals._
18* **API support and customizations for Ravenwood appear directly inline with relevant code.** This improves maintenance of APIs by providing awareness of what code runs under Ravenwood, including the ability to replace code at a per-method level when Ravenwood-specific customization is needed.
19    * _Contrasted with Robolectric which maintains customized behavior in separate “Shadow” classes that are difficult for maintainers to be aware of._
20* **APIs supported under Ravenwood are tested to remain consistent with physical devices.**  As teams progressively opt-in supporting APIs under Ravenwood, we’re requiring they bring along “bivalent” tests (such as the relevant CTS) to validate that Ravenwood behaves just like a physical device.
21    * _Contrasted with Robolectric, which has limited (and forked) testing of their environment, increasing their risk of accidental divergence over time and misleading “passing” signals._
22* **Ravenwood aims to support more “real” code.**  As API owners progressively opt-in their code, they have the freedom to provide either a limited “fake” that is a faithful emulation of how a device behaves, or they can bring more “real” code that runs on physical devices.
23    * _Contrasted with Robolectric, where support for “real” code ends at the app process boundary, such as a call into `system_server`._
24
25## More details
26
27* [Ravenwood for Test Authors](test-authors.md)
28* [Ravenwood for API Maintainers](api-maintainers.md)
29