Compose se integra con frameworks de prueba comunes.
Interoperabilidad con Espresso
En una app híbrida, puedes encontrar componentes de Compose dentro de jerarquías de vistas y vistas en elementos componibles de Compose (a través del elemento componible AndroidView
).
No es necesario realizar pasos especiales para coincidir con alguno de los tipos. Haces coincidir las vistas con onView
de Espresso y los elementos de Compose con ComposeTestRule
.
@Test
fun androidViewInteropTest() {
// Check the initial state of a TextView that depends on a Compose state.
Espresso.onView(withText("Hello Views")).check(matches(isDisplayed()))
// Click on the Compose button that changes the state.
composeTestRule.onNodeWithText("Click here").performClick()
// Check the new value.
Espresso.onView(withText("Hello Compose")).check(matches(isDisplayed()))
}
Interoperabilidad con UiAutomator
De forma predeterminada, solo se puede acceder a los elementos componibles desde UiAutomator a través de sus descriptores convenientes (texto mostrado, descripción del contenido, etcétera). Si quieres acceder a cualquier elemento componible que use Modifier.testTag
, debes habilitar la propiedad semántica testTagsAsResourceId
para el subárbol del elemento componible en particular. Habilitar este comportamiento es útil para elementos componibles que no tienen ningún otro controlador único, como los que se pueden desplazar (por ejemplo, LazyColumn
).
Habilita la propiedad semántica solo una vez en la parte superior de la jerarquía de elementos componibles para asegurarte de que se pueda acceder a todos los elementos componibles anidados con Modifier.testTag
desde UiAutomator.
Scaffold(
// Enables for all composables in the hierarchy.
modifier = Modifier.semantics {
testTagsAsResourceId = true
}
){
// Modifier.testTag is accessible from UiAutomator for composables nested here.
LazyColumn(
modifier = Modifier.testTag("myLazyColumn")
){
// Content
}
}
Se puede acceder a cualquier elemento componible con Modifier.testTag(tag)
mediante el uso de By.res(resourceName)
con el mismo tag
que resourceName
.
val device = UiDevice.getInstance(getInstrumentation())
val lazyColumn: UiObject2 = device.findObject(By.res("myLazyColumn"))
// Some interaction with the lazyColumn.
Recursos adicionales
- Cómo probar apps en Android: La página principal de pruebas de Android proporciona una vista más amplia de los aspectos básicos y las técnicas de las pruebas.
- Fundamentos de las pruebas: Obtén más información sobre los conceptos básicos de las pruebas de una app para Android.
- Pruebas locales: Puedes ejecutar algunas pruebas de forma local en tu propia estación de trabajo.
- Pruebas instrumentadas: También se recomienda ejecutar pruebas instrumentadas. Es decir, pruebas que se ejecutan directamente en el dispositivo.
- Integración continua: La integración continua te permite integrar tus pruebas en tu canalización de implementación.
- Prueba diferentes tamaños de pantalla: Con tantos dispositivos disponibles para los usuarios, debes probar diferentes tamaños de pantalla.
- Espresso: Si bien está diseñado para las IU basadas en View, el conocimiento de Espresso puede ser útil para algunos aspectos de las pruebas de Compose.