Lineamientos de calidad básicos de las apps

Para proporcionar una base sólida para una app de calidad, sigue los lineamientos principales de calidad para apps.

Los lineamientos definen la calidad mínima que deben cumplir todas las apps.

Calidad de las apps adaptativas

Las apps para Android se ejecutan en una amplia variedad de dispositivos, desde teléfonos compactos hasta tablets, plegables, computadoras de escritorio, pantallas conectadas, sistemas de infoentretenimiento para automóviles, TVs y XR. Los modos de ventanas, como el de pantalla dividida y el de ventanas de escritorio, permiten que las apps se ejecuten en porciones redimensionables de una pantalla.

Sigue los lineamientos de calidad de apps adaptables, junto con los principales lineamientos de calidad de las apps, para hacer lo siguiente:

  • Crea apps optimizadas para todos los factores de forma y tamaños de pantalla
  • Mejora el posicionamiento de tus apps en las fichas y la búsqueda de Google Play
  • Adquirir más usuarios y aumentar la retención de usuarios

Lineamientos

Los siguientes lineamientos principales te ayudan a compilar una app básica de alta calidad.

Experiencia del usuario

Los patrones de interacción y diseño visual estándares de Android proporcionan una experiencia del usuario intuitiva y coherente.

Usa componentes de Material Design para crear la interfaz de usuario de tu app en lugar de los componentes de la plataforma de Android siempre que sea posible. Material Design proporciona una apariencia y un estilo modernos de Android, además de coherencia en la IU en todas las versiones de Android.

Usabilidad

ID Pruebas Descripción
Consistent_UX T-Consistent_UX,
T-SD_Card
La app proporciona una experiencia del usuario coherente para todos los casos de uso de la app en todos los factores de forma.
App_Switcher T-App_Switcher,
T-SD_Card
La app pasa a segundo plano cuando el enfoque cambia a otra app. La app regresa a primer plano cuando se reactiva desde el conmutador de apps Recientes.
Sleep_Resume T-Sleep_Resume,
T-SD_Card
Cuando la app está en primer plano, se pausa cuando el dispositivo entra en modo de suspensión y se reanuda cuando se activa.
Lock_Resume T-Lock_Resume,
T-SD_Card
Cuando la app está en primer plano, se pausa cuando se bloquea el dispositivo y se reanuda cuando se desbloquea.

Interfaz de usuario

ID Pruebas Descripción
Display_State_Parity T-Orientation_Transitions

Las orientaciones de pantalla y los estados de plegado exponen esencialmente las mismas funciones y acciones, y conservan la paridad funcional.

Fullscreen_Display T-Orientation_Transitions

La app ocupa la ventana de la app en ambas orientaciones y no está en formato letterbox debido a cambios de configuración, incluidos el plegado y el desplegado del dispositivo.

Se acepta el uso mínimo de formato de pantalla ancha para compensar pequeñas variaciones en la geometría de la pantalla.

Orientation_Transitions T-Orientation_Transitions La app controla las transiciones rápidas entre las orientaciones de la pantalla y el plegado o desplegado del dispositivo sin presentar problemas de renderización de la pantalla ni perder el estado.

Calidad visual

ID Pruebas Descripción
Graphic_Quality T-Graphic_Quality

La app muestra gráficos, texto, imágenes y otros elementos de la IU sin distorsión, esfumado ni pixelado notables.

  • La app usa elementos de diseño vectoriales cuando es posible
  • La app usa gráficos de alta calidad para todos los tamaños de pantalla y factores de forma objetivo
  • No se observa suavizado en los bordes de los menús, los botones ni otros elementos de la IU.
Line_Length T-Line_Length La app garantiza la legibilidad del texto y los bloques de texto limitando la longitud de la línea a entre 45 y 75 caracteres (incluidos los espacios) para cada uno de los idiomas que admite.
Theme_Support T-Theme_Support El contenido de la app y todo el contenido web al que accede la app admiten los temas claro y oscuro.
ID Pruebas Descripción
Back_Button_Nav T-Back_Nav La app admite la navegación estándar del botón Atrás y no utiliza avisos personalizados en pantalla para este.
Back_Gesture_Nav T-Back_Nav La app admite la navegación por gestos para volver atrás y navegar a la pantalla principal.
State_Preservation T-State_Preservation,
T-Back_Nav

La app preserva el estado del usuario o la app cuando abandona el primer plano y evita la pérdida accidental de datos a causa de la navegación hacia atrás y otros cambios de estado.

Cuando regresa al primer plano, la app restablece el estado preservado y cualquier transacción con estado pendiente. Algunos ejemplos incluyen cambios en campos editables, progreso de un juego, menús, videos y otras secciones de la app.

  • Cuando se reanuda la app desde el conmutador de apps Recientes, la app regresa al usuario al estado exacto en que se encontraba la última vez que este la utilizó.
  • Cuando se reanuda la app después de la activación del dispositivo (luego de haber estado bloqueado), esta regresa al usuario al estado exacto en que se encontraba en la última utilización.
  • Cuando se reinicie desde Página principal o Todas las apps, la app debería realizar una de las siguientes acciones, según cuánto tiempo haya transcurrido desde la última utilización:
    • Si la app se usó por última vez hace poco tiempo (minutos), restablece el estado de la app lo más cerca posible de su estado anterior.
    • Si pasó más tiempo desde que se usó la app por última vez, restablécela lo más cerca posible de su estado anterior o iníciala en su pantalla principal o en cualquier otro estado predeterminado.

Notificaciones

ID Pruebas Descripción
Notification_Quality T-Notification_Quality

Las notificaciones proporcionan información relevante relacionada con tu app.

  • No uses las notificaciones para realizar promoción cruzada ni para publicitar otro producto, ya que Play Store lo prohíbe de forma estricta.
  • Los canales de notificaciones se definen según las prácticas recomendadas, en lugar de entregar todas las notificaciones desde un canal único.
  • Selecciona la prioridad de notificación correcta.
  • Cuando sea posible, consolida varias notificaciones en un solo grupo de notificaciones.
  • Establece tiempos de espera para las notificaciones cuando sea necesario.
  • Las notificaciones solo son recurrentes si están relacionadas con eventos actuales (como la reproducción de música o una llamada telefónica). Para obtener más información, consulta la sección Funcionalidad.
Conversation_Quality T-Notification_Quality

Para apps de mensajería o sociales y conversaciones:

Accesibilidad

ID Pruebas Descripción
Touch_Target_Size T-Touch_Target_Size Los objetivos táctiles tienen al menos 48 dp. Consulta los lineamientos de diseño y tipografía de Material Design.
Visual_Contrast T-Visual_Contrast

El texto y el contenido en primer plano de la app mantienen las siguientes relaciones de contraste con el fondo de la app:

  • 3:1 para texto y gráficos grandes
  • 4.5:1 para texto pequeño (menos de 18 pt o menos de 14 pt si el texto está en negrita)

Obtén más información sobre el color y el contraste.

Content_Description T-Content_Description Describe cada elemento de la IU, excepto TextView, con contentDescription.

Funcionalidad

Tu app deberá implementar el siguiente comportamiento funcional.

Audio

ID Pruebas Descripción
Audio_Playback_Start T-Audio_Playback_Start

Cuando el usuario inicie la reproducción de audio, la app deberá realizar una de las siguientes acciones antes de que transcurra un segundo:

  • Comenzar a reproducir el audio
  • Proporcionar un indicador visual de que los datos de audio se están preparando
Audio_Focus_Request T-Audio_Focus_Request La app deberá solicitar foco de audio cuando el audio comience a reproducirse y deberá abandonarlo cuando se detenga la reproducción.
Audio_Focus_Change T-Audio_Focus_Change La app debe controlar las solicitudes de foco de audio de otras apps. Por ejemplo, una app podría bajar el volumen de reproducción cuando otra reproduzca contenido de voz.
Audio_Playback_Background T-Audio_Playback_Background

La app debe admitir la reproducción en segundo plano.

La app debe usar un servicio en primer plano para evitar que el sistema cierre el proceso de la app una vez que esta deje de estar visible. La app también debe mostrar una notificación persistente que no se pueda descartar en la barra de estado o en la pantalla de bloqueo para informar al usuario que la app se está ejecutando.

Los usuarios deben poder controlar la reproducción con los controles de la notificación o de la pantalla de bloqueo, o bien con los controles de un accesorio conectado.

Audio_Notification_Style T-Audio_Notification_Style Cuando la app reproduce audio en segundo plano, debe crear una notificación con el estilo MediaStyle.
Audio_Playback_Resume T-Audio_Playback_Resume Si la app está en segundo plano y el audio está pausado, la reproducción de audio continúa cuando la app regresa a primer plano, o la app debe indicarle al usuario que la reproducción está pausada.

Video

ID Pruebas Descripción
Video_PiP T-Video_PiP Si la app reproduce video, deberá admitir la reproducción pantalla en pantalla.
Video_Encoding T-Video_Encoding Si la app codifica contenido de video, deberá hacerlo con el estándar de compresión de video HEVC.
Video_Playback_Background T-Video_Playback_Background

La app admite la reproducción de video en segundo plano cuando no es la app superior, incluso cuando la ventana de la app se encuentra en las siguientes situaciones:

  • Minimizado
  • Detrás de otras ventanas o la IU del sistema (por ejemplo, la sombra de notificaciones o la pantalla de inicio/bloqueo)
  • Fuera de la pantalla visible del escritorio

Uso compartido

ID Pruebas Descripción
System_Sharesheet T-System_Sharesheet La app deberá usar Android Sharesheet cuando comparta contenido. La app puede sugerir objetivos que no están disponibles para las soluciones personalizadas.

Servicios en segundo plano

ID Pruebas Descripción
Background_Service_Optimization T-Background_Service_Optimization

La app evita que se ejecuten servicios innecesariamente largos en segundo plano para garantizar que el dispositivo del usuario funcione sin problemas.

Nota: El sistema aplica varias restricciones a los servicios en segundo plano.

Los siguientes son usos inadecuados de los servicios en segundo plano:

  • Mantener una conexión de red para las notificaciones
  • Mantener una conexión Bluetooth
  • Mantener el GPS encendido

Para obtener más información, consulta Descripción general de las tareas en segundo plano.

Rendimiento y estabilidad

Tu app debe proporcionar un rendimiento, una estabilidad, una compatibilidad y una capacidad de respuesta óptimos.

Rendimiento

ID Pruebas Descripción
App_Startup_Time T-App_Startup_Time La app se carga rápidamente o le proporciona al usuario comentarios en pantalla (como un indicador de progreso o una señal similar) en el caso de que tarde más de dos segundos en cargarse.
Rendering_Performance T-Rendering_Performance La app renderiza fotogramas cada 16 (o menos) milisegundos para mostrar al menos 60 fotogramas por segundo. Si necesitas ayuda con problemas de procesamiento, consulta Procesamiento lento.
StrictMode_Compliance T-StrictMode_Compliance Con StrictMode habilitado (consulta la sección de pruebas de StrictMode), no se verán destellos rojos (advertencias de rendimiento de StrictMode) durante la prueba de la app.

Estabilidad

ID Pruebas Descripción
Stability_ANR T-Stability_ANR La app no falla ni bloquea el subproceso de IU que provoca errores de ANR (Android no responde). Usa el informe previo al lanzamiento de Google Play para identificar posibles problemas de estabilidad. Después de la implementación, supervisa la página Android vitals en Google Play Console.

SDK

ID Pruebas Descripción
Android_Platform_Compatibility T-Android_Platform_Compatibility La app se ejecuta en la versión pública más reciente de la plataforma de Android sin fallar ni afectar gravemente la funcionalidad principal.
Target_SDK_Version T-Target_SDK_Version La app se orienta al SDK de Android más reciente necesario para alinearse con los requisitos de Google Play estableciendo el valor targetSdk en el archivo build.gradle del módulo de la app.
Compile_SDK_Version T-Target_SDK_Version La app se compila con el SDK de Android más reciente estableciendo el valor compileSdk en el archivo build.gradle del módulo de la app.
SDK_Maintenance T-SDK_Maintenance,
T-Non_SDK_Interfaces

Todos los SDKs de Google o de terceros que se usan están actualizados. Cualquier mejora que se realice a estos SDKs relacionada con la estabilidad, la compatibilidad o la seguridad debe estar disponible de forma oportuna para los usuarios.

Para los SDKs de Google, usa los SDKs con la tecnología de los Servicios de Google Play cuando estén disponibles. Estos SDKs son retrocompatibles, reciben actualizaciones automáticas, reducen el tamaño del paquete de la app y hacen un uso eficiente de los recursos integrados en el dispositivo.

Non_SDK_Interfaces T-Non_SDK_Interfaces La app no usa interfaces que no pertenecen al SDK.
Production_Build_Quality T-Production_Build_Quality No se incluyen bibliotecas de depuración en la app de producción. Las bibliotecas de depuración incluidas en la app pueden causar problemas de rendimiento y de seguridad.

Batería

ID Pruebas Descripción
Power_Management T-Power_Management

La app admite correctamente las funciones de administración de energía Descanso y App Standby.

Las apps pueden solicitar una exención de mantenimiento de energía. Consulta Compatibilidad con otros casos de uso en Cómo optimizar tu app para Descanso y App Standby.

Privacidad y seguridad

La app administra de forma segura los datos del usuario y su información personal, y proporciona los niveles de permisos adecuados.

Las aplicaciones publicadas en Google Play Store también deben cumplir con las políticas de Datos del Usuario de Google Play para proteger la privacidad del usuario.

Permisos

ID Pruebas Descripción
Minimize_Permissions T-Minimize_Permissions La app solicita solo los permisos mínimos absolutos necesarios para admitir el caso de uso actual. Para algunos permisos, como la ubicación, la app usa una especificación aproximada en lugar de precisa si es posible. Consulta Cómo minimizar las solicitudes de permiso.
Sensitive_Permissions T-Sensitive_Permissions

La app solicita permiso para acceder a datos sensibles (como los grupos de permisos de SMS o Registro de llamadas o la ubicación) o a servicios que cuestan dinero (como el Teléfono o los SMS) solo cuando están directamente relacionados con los casos de uso principales de la app. Las consecuencias relacionadas con estos permisos se deben divulgar de manera destacada al usuario.

Según cómo use tu app los permisos, es posible que haya una forma alternativa de cumplir con el caso de uso de tu app sin depender del acceso a información sensible. Por ejemplo, en lugar de solicitar permisos relacionados con los contactos de un usuario, usa un intent implícito para solicitar acceso.

Runtime_Permissions T-Runtime_Permissions La app solicita permisos de tiempo de ejecución cuando se solicita la funcionalidad, en lugar de hacerlo durante el inicio de la app.
Permission_Rationale T-Permission_Rationale La app explica claramente por qué se necesitan los permisos.
Graceful_Degradation T-Graceful_Degradation La app se degrada de manera elegante cuando los usuarios rechazan o revocan un permiso. La app no debe impedir el acceso del usuario por completo.

Datos y archivos

ID Pruebas Descripción
Sensitive_Data_Storage T-Sensitive_Data_Storage,
T-Sensitive_Data_Handling
Todos los datos sensibles se almacenan en el almacenamiento interno de la app.
Sensitive_Data_Logging T-Sensitive_Data_Logging No se registran datos personales o sensibles de los usuarios en el registro del sistema ni en un registro específico de la app.
Hardware_IDs T-Hardware_IDs La app no usa IDs de hardware que no se puedan restablecer, como el IMEI, para fines de identificación.

Identidad

ID Pruebas Descripción
Autofill_Hints T-Autofill_Hints La app brinda sugerencias para autocompletar las credenciales de la cuenta y otra información sensible, como datos de tarjetas de crédito, direcciones físicas y números de teléfono.
Credential_Manager T-Credential_Manager La app integra Credential Manager para Android para brindar una experiencia de acceso fluida que unifica la compatibilidad con llaves de acceso, identidades federadas y contraseñas.
Biometric_Authentication T-Biometric_Authentication La app admite la autenticación biométrica para proteger las transacciones financieras y la información sensible, como los documentos importantes de los usuarios.

Componentes de la aplicación

ID Pruebas Descripción
Component_Export T-Component_Export

La app establece el atributo android:exported de forma explícita para todas las actividades, los servicios, los receptores de emisión y, en especial, los proveedores de contenido.

Solo se exportan los componentes de la aplicación que comparten datos con otras apps o aquellos que otras apps deberían invocar.

Component_Permissions T-Component_Permissions

Todos los intents y transmisiones siguen las prácticas recomendadas:

Component_Protection T-Component_Protection

Todos los componentes que comparten contenido entre apps usan android:protectionLevel="signature" para los permisos personalizados. Esto incluye actividades, servicios, receptores de emisión y, en especial, proveedores de contenido.

Las apps no deben depender del acceso a una lista de paquetes instalados.

Redes

ID Pruebas Descripción
Network_Security_Traffic T-Network_Security_Traffic Todo el tráfico de red se envía mediante SSL.
Network_Security_Configuration T-Network_Security_Configuration La app declara una configuración de seguridad de red.
Security_Provider_Initialization T-Security_Provider_Initialization Si la app usa los Servicios de Google Play, se inicializará el proveedor de seguridad cuando lo haga la app.

WebViews

ID Pruebas Descripción
WebView_Asset_Loader T-WebView_Asset_Loader,
T-WebView_Navigation
No uses setAllowUniversalAccessFromFileURLs() para acceder al contenido local. En su lugar, usa WebViewAssetLoader.
WebView_JavaScript T-WebView_JavaScript,
T-WebView_Navigation

Las vistas web no usan addJavaScriptInterface() con contenido que no es de confianza.

En su lugar, en Android 6.0 (nivel de API 23 y versiones posteriores), usa los canales de mensajes HTML.

Ejecución

ID Pruebas Descripción
App_Bundles T-App_Bundles

La app no carga código dinámicamente desde fuera del APK de la app. Usa Android App Bundles, que incluyen Play Feature Delivery y Play Asset Delivery.

A partir de agosto de 2021, el uso de Android App Bundles es obligatorio para todas las apps nuevas en Google Play Store.

Criptografía

ID Pruebas Descripción
Cryptographic_Algorithms T-Cryptographic_Algorithms La app usa algoritmos criptográficos y un generador de números aleatorios sólidos proporcionados por la plataforma. Además, la app no implementa algoritmos personalizados.

Google Play

Habilita la publicación de tu app en Google Play.

Políticas

ID Pruebas Descripción
Play_Content_Policies T-Play_Content_Policies La app cumple estrictamente con los términos de la Política de Contenido para Desarrolladores de Google Play, no ofrece contenido inapropiado ni utiliza la propiedad intelectual o la marca de otros.
Play_Content_Rating T-Play_Content_Policies El nivel de madurez de la app se establece de forma correcta en función de los Lineamientos de Clasificación del Contenido.

Página de detalles de la app

ID Pruebas Descripción
Play_Feature_Graphic T-Play_Feature_Graphic,
T-Play_Graphic_Assets

El gráfico de funciones de la app sigue los lineamientos que se describen en este artículo de asistencia. Asegúrate de cumplir con lo siguiente:

  • El directorio de la app incluye un gráfico central de alta calidad
  • El gráfico central no contiene imágenes de dispositivos, capturas de pantalla ni texto pequeño que resulte ilegible cuando la app se reduzca en tamaño para visualizarse en el tamaño más pequeño de pantalla que tu app admita.
  • El gráfico central no se parece a un anuncio publicitario.
Play_Device_References T-Play_Graphic_Assets Las capturas de pantalla y los videos de la app no muestran ni hacen referencia a dispositivos que no sean Android.
Play_Misleading_Content T-Play_Graphic_Assets Las capturas de pantalla o los videos de la app no representan el contenido ni la experiencia que ofrece tu app de forma confusa.

Asistencia al usuario

ID Pruebas Descripción
Play_User_Reviews T-Play_Content_Policies Los errores comunes informados por los usuarios en la pestaña Reseñas de la página de Google Play se abordan siempre que se puedan reproducir y ocurran en muchos dispositivos diferentes. Si se produce un error en unos pocos dispositivos, aún debes abordarlo en caso de que esos dispositivos sean especialmente populares o nuevos.

Entorno de pruebas

Configura un entorno de pruebas de la siguiente manera:

  • Pruebas de emulador: Android Emulator es una excelente manera de probar tu app en diferentes versiones de Android y resoluciones de pantalla. Configura dispositivos emulados (AVDs) para representar los factores de forma y las combinaciones de hardware y software más comunes para tu base de usuarios objetivo. Prueba una variedad de factores de forma con los siguientes emuladores (como mínimo):

    • Dispositivos plegables: 7.6" con pantalla plegable (se muestra en teléfonos en el Administrador de AVD)
    • Tablet: Pixel C 9.94" (2,560 px x 1,800 px)
    • Pruebas de notificaciones de apps para dispositivos móviles: Vincula un dispositivo móvil o emulador con el emulador de Wear OS: Wear OS redondo de 1.84".
  • Dispositivos de hardware: El entorno de pruebas debe incluir una pequeña cantidad de dispositivos de hardware reales que representen los factores de forma y las combinaciones de hardware y software claves que se encuentren disponibles para los consumidores. No es necesario que hagas pruebas en todos los dispositivos disponibles en el mercado. Concéntrate en una pequeña cantidad de dispositivos representativos, incluso puedes usar uno o dos dispositivos por factor de forma.

  • Test Labs de dispositivos: También puedes usar servicios de terceros, como Firebase Test Lab, para probar tu app en una amplia variedad de dispositivos.

  • Prueba con la última versión de Android: Además de probar versiones representativas de Android para tu base de usuarios objetivo, siempre debes hacer pruebas con la última versión de Android para asegurarte de que los cambios de comportamiento más recientes no afecten negativamente la experiencia del usuario de tu app.

Si deseas obtener más orientación sobre las pruebas, incluidas las pruebas de unidades, las pruebas de integración y las pruebas de IU, consulta Fundamentos de la prueba de apps para Android.

StrictMode

Para las pruebas de rendimiento, habilita StrictMode en tu app. Usa StrictMode para detectar operaciones que podrían afectar el rendimiento, el acceso a la red y la lectura y escritura de archivos. Busca operaciones potencialmente problemáticas en el subproceso principal y en otros.

Establece una política de supervisión por subproceso con StrictMode.ThreadPolicy.Builder y habilita toda la supervisión compatible en ThreadPolicy con detectAll().

Habilita la notificación visual de los incumplimientos de políticas para la ThreadPolicy con penaltyFlashScreen().

Pruebas

Las pruebas de calidad de la app principal te ayudan a evaluar la calidad fundamental de tu app. Puedes combinar las pruebas o integrar grupos de pruebas en tu plan de prueba.

Experiencia del usuario

Prueba si la experiencia del usuario es coherente e intuitiva.

Usabilidad

ID Función Descripción
T-Consistent_UX Consistent_UX

Navega a todas las partes de la app (pantallas, diálogos, configuraciones y flujos de usuarios).

Sigue estos pasos:
  • Si la aplicación permite editar o crear contenido, jugar o reproducir contenido multimedia, asegúrate de probar esos flujos.
  • Mientras pruebas la app, genera interrupciones provenientes de otras apps, como recibir una notificación o una llamada telefónica, y aplica cambios transitorios en los atributos del dispositivo, como la conectividad de red, la función de la batería, la disponibilidad del GPS y la carga del sistema.
  • Ingresa y prueba todos los flujos de compra directa desde la aplicación.
T-App_Switcher App_Switcher Desde cada una de las pantallas de la app, pasa a otra que se esté ejecutando y luego regresa a la app que estés probando con el conmutador de apps Recientes.
T-Sleep_Resume Sleep_Resume Presiona el botón de encendido para colocar el dispositivo en modo de suspensión y luego presiona nuevamente el botón de encendido para reactivar la pantalla.
T-Lock_Resume Lock_Resume Establece un bloqueo de pantalla en el dispositivo. Presiona el botón de encendido para colocar el dispositivo en modo de suspensión (el cual bloquea el dispositivo). A continuación, vuelve a presionar el botón de encendido para activar la pantalla y desbloquear el dispositivo.

Tarjeta SD

ID Función Descripción
T-SD_Card Consistent_UX

Realiza pruebas de funcionalidad principal con la app instalada en la tarjeta SD del dispositivo (si la app admite este método de instalación).

Para mover la app a una tarjeta SD, consulta la Configuración de la app.

Interfaz de usuario

ID Función Descripción
T-Orientation_Transitions Display_State_Parity,
Fullscreen_Display,
Orientation_Transitions

Desde cada una de las pantallas de la app, gira el dispositivo entre la orientación horizontal y vertical, y los estados plegado y desplegado, al menos tres veces.

Verifica que la app haga lo siguiente:
  • Proporciona paridad de funciones en todas las orientaciones de pantalla y estados de plegado
  • Ocupa la ventana de la app en todas las orientaciones de pantalla y estados de plegado, y no está en formato letterbox.
  • Mantiene el estado y no presenta problemas de renderización durante las transiciones rápidas entre las orientaciones y el plegado y desplegado del dispositivo

Calidad visual

ID Función Descripción
T-Graphic_Quality Graphic_Quality Usa todas las funciones de tu app. Verifica que todos los elementos visuales, incluidos los gráficos, el texto, las imágenes y otros elementos de la IU, no presenten distorsión, esfumado ni pixelado.
T-Line_Length Line_Length

Revisa todos los bloques de texto de la app. Verifica que la longitud de la línea de texto y del bloque de texto se limite a entre 45 y 75 caracteres (incluidos los espacios) para garantizar la legibilidad.

Verifica lo siguiente:
  • La composición es aceptable en todos los factores de forma compatibles
  • No se visualizan letras ni palabras cortadas.
  • No se visualizan ajustes automáticos de línea incorrectos en botones ni íconos
  • Espacio suficiente entre el texto y los elementos circundantes
T-Theme_Support Theme_Support Verifica que todo el texto sea legible en los temas claros y oscuros. Verifica que todos los elementos visuales sean claramente discernibles y estéticos en los temas claros y oscuros.
ID Función Descripción
T-Back_Nav Back_Button_Nav,
Back_Gesture_Nav

Navega a todas las partes de la app (pantallas, diálogos, configuraciones y flujos de usuarios).

Desde cada una de las pantallas de la app, presiona el botón Atrás o usa el gesto para deslizar hacia atrás. La app debe navegar a la pantalla anterior o principal.

T-State_Preservation State_Preservation Desde cada una de las pantallas de la app, presiona la tecla Inicio del dispositivo o desliza el dedo hacia arriba en la navegación por gestos y vuelve a iniciar la app desde la pantalla Todas las apps.

Notificaciones

ID Función Descripción
T-Notification_Quality Notification_Quality,
Conversation_Quality
Inicia la app y observa en el panel lateral de notificaciones todos los tipos de notificaciones que la app puede mostrar. Cuando sea posible (en Android 4.1 y versiones posteriores), expande las notificaciones y presiona todas las acciones disponibles.

Accesibilidad

ID Función Descripción
T-Touch_Target_Size Touch_Target_Size Verifica que los objetivos táctiles mantengan una posición y un tamaño coherentes y accesibles para todos los tamaños y las configuraciones de pantalla. Para obtener información sobre accesibilidad, consulta la Prueba de accesibilidad.
T-Visual_Contrast Visual_Contrast Verifica el contraste de todos los elementos visuales.
T-Content_Description Content_Description Verifica que todos los elementos de la IU, excepto TextView, tengan descripciones de contenido.

Funcionalidad

Verifica que tu app implemente el siguiente comportamiento funcional.

Audio

ID Función Descripción
T-Audio_Playback_Start Audio_Playback_Start Inicia la reproducción de audio. Verifica que, en un segundo, la app comience a reproducir el audio o proporcione un indicador visual de que los datos de audio se están preparando para la reproducción.
T-Audio_Focus_Request Audio_Focus_Request Inicia la reproducción de audio. La app debe solicitar el foco de audio. Cuando se detiene la reproducción de audio, la app debe liberar el foco de audio (lo que sucede automáticamente en las apps que se segmentan para Android 12 (nivel de API 31) y versiones posteriores).
T-Audio_Focus_Change Audio_Focus_Change Inicia la reproducción de audio. Inicia la reproducción de audio en otra app. Tu app debe responder al cambio en el foco de audio y detener la reproducción de audio o reducir el volumen de reproducción.
T-Audio_Playback_Background Audio_Playback_Background

Inicia la reproducción de audio. Interactúa con otra app que no sea de audio como la app en primer plano. La app debe seguir reproduciendo audio en segundo plano y mostrar una notificación en la barra de estado. Verifica que puedas administrar la reproducción con los controles que se muestran en la notificación.

Bloquea la pantalla del dispositivo. La app debe seguir reproduciendo audio en segundo plano y mostrar una notificación en la pantalla de bloqueo. Verifica que puedas administrar la reproducción con los controles que se muestran en la notificación.

T-Audio_Notification_Style Audio_Notification_Style Inicia la reproducción de audio. Interactúa con otra app que no sea de audio como la app en primer plano. Verifica que tu app siga reproduciendo audio en segundo plano y que haya creado una notificación con el estilo MediaStyle. Consulta Cómo interactuar correctamente con los controles de contenido multimedia.
T-Audio_Playback_Resume Audio_Playback_Resume Inicia la reproducción de audio. Interactúa con otra app que no sea de audio como app en primer plano. Interactúa con tu app para que sea la app principal. El audio debería reanudarse o el volumen debería restablecerse. De lo contrario, la app debe indicarle al usuario que la reproducción está pausada.

Video

ID Función Descripción
T-Video_PiP Video_PiP Activa la reproducción de video en modo de pantalla en pantalla de la app.
T-Video_Encoding Video_Encoding Verifica que la app codifique el video con el estándar de compresión de video HEVC.
T-Video_Playback_Background Video_Playback_Background Inicia la reproducción del video. Minimiza la ventana de la app y abre otra para mover la ventana de la app al segundo plano. En dispositivos aptos para computadoras, mueve la ventana de la app fuera del escritorio visible. Verifica que la reproducción de video continúe sin interrupciones en todos los casos.

Uso compartido

ID Función Descripción
T-System_Sharesheet System_Sharesheet Crea un intent y llama a startActivity() con el intent como argumento para iniciar una actividad. Consulta Cómo usar Android Sharesheet. Tu app debería mostrar Android Sharesheet.

Servicios en segundo plano

ID Función Descripción
T-Background_Service_Optimization Background_Service_Optimization

Usa todas las funciones principales de tu app y verifica que no se inicien servicios en segundo plano de larga duración.

Cambia a otra app para enviar la tuya a segundo plano. Ve a Configuración y comprueba si tu app tiene servicios ejecutándose mientras se encuentra en segundo plano. En Android 4.0 y versiones posteriores, ve a la pantalla Apps y busca la app en la pestaña En ejecución.

Rendimiento y estabilidad

Verifica el rendimiento, la estabilidad y los elementos visuales perfectos en píxeles.

Rendimiento

ID Función Descripción
T-App_Startup_Time App_Startup_Time Inicia tu app. Verifica que se cargue rápidamente o que proporcione un indicador de progreso o una señal similar si tarda más de dos segundos en cargarse.
T-Rendering_Performance Rendering_Performance Usa todas las funciones principales de tu app y verifica que se renderice a, al menos, 60 fotogramas por segundo. Usa la opción Profile HWUI rendering para probar tu app.
T-StrictMode_Compliance StrictMode_Compliance

Habilita StrictMode en tu app y usa todas las funciones principales. Verifica que la app no produzca ninguna advertencia de rendimiento de StrictMode, es decir, que no se vean destellos rojos cuando se pruebe la app. Los destellos rojos indican un comportamiento inadecuado en relación con el almacenamiento, el acceso a la red o la administración de la memoria (como las fugas de memoria).

Presta mucha atención a la recolección de elementos no utilizados y su impacto en la experiencia del usuario.

Estabilidad

ID Función Descripción
T-Stability_ANR Stability_ANR Usa todas las funciones principales de tu app. Verifica que la app no falle ni bloquee el subproceso de IU, lo que provocaría errores ANR (Android no responde). Revisa el informe previo al lanzamiento de Google Play para identificar posibles problemas de estabilidad.

SDK

ID Función Descripción
T-Android_Platform_Compatibility Android_Platform_Compatibility Ejecuta tu app en la versión pública más reciente de la plataforma de Android. Usar todas las funciones principales Verifica que la app no falle y que se ejecute sin pérdida de la funcionalidad principal.
T-Target_SDK_Version Target_SDK_Version,
Compile_SDK_Version
Revisa el archivo de manifiesto de Android y la configuración de compilación para asegurarte de que la aplicación esté compilada con la última versión disponible del SDK (targetSdk y compileSdk).
T-SDK_Maintenance SDK_Maintenance Revisa el archivo build.gradle de tu app para comprobar si hay dependencias desactualizadas.
T-Non_SDK_Interfaces Non_SDK_Interfaces Usa la herramienta lint de Android Studio para detectar el uso de interfaces que no pertenezcan al SDK. Consulta Restricciones en interfaces que no pertenecen al SDK para conocer otros métodos de prueba.
T-Production_Build_Quality Production_Build_Quality Revisa el archivo build.gradle de tu app para ver si incluye bibliotecas de depuración.

Batería

ID Función Descripción
T-Power_Management Power_Management

Usa todas las funciones principales de la app en los modos Descanso y App Standby. Verifica que las alarmas, los temporizadores, las notificaciones y las sincronizaciones funcionen correctamente en la ventana de mantenimiento de Doze y cuando la app salga del modo App Standby.

Prueba el comportamiento de Descanso y App Standby con comandos de ADB (consulta Pruebas con Descanso y App Standby para conocer los requisitos y lineamientos).

Para diagnosticar el agotamiento inesperado de la batería, usa el Generador de perfiles de energía de Android Studio o la herramienta Battery Historian combinados con el trabajo en segundo plano planificado.

Privacidad y seguridad

Prueba las protecciones de privacidad y seguridad que esperan los usuarios.

Permisos

ID Función Descripción
T-Minimize_Permissions Minimize_Permissions Revisa todos los permisos que tu app requiere en el archivo de manifiesto, el tiempo de ejecución y la configuración de la app en el dispositivo (Configuración > Información de la app).
T-Sensitive_Permissions Sensitive_Permissions Usar cualquier función de la app que solicite permisos Verifica que la app solicite permiso para acceder a datos o servicios sensibles solo para los casos de uso principales de la app. Verifica que las implicaciones de otorgar permiso a datos y servicios sensibles se comuniquen claramente al usuario.
T-Runtime_Permissions Runtime_Permissions Usa todas las funciones de tu app que requieran permisos. Verifica que los permisos se soliciten de forma diferida, es decir, solo cuando se accede a las funciones, en lugar de hacerlo durante el inicio de la app.
T-Permission_Rationale Permission_Rationale Usa todas las funciones de tu app que requieran permisos. Verifica que la app le explique al usuario por qué se necesitan los permisos.
T-Graceful_Degradation Graceful_Degradation Usa todas las funciones de tu app que requieran permisos. Rechaza o revoca los permisos. Verifica que la app proporcione un caso de uso alternativo y siga funcionando.

Datos y archivos

ID Función Descripción
T-Sensitive_Data_Storage Sensitive_Data_Storage Revisa todos los datos almacenados en el almacenamiento interno. Verifica que los datos almacenados de forma externa no sean sensibles.
T-Sensitive_Data_Handling Sensitive_Data_Storage Revisa cómo se controlan y procesan los datos que se cargan desde el almacenamiento externo.
T-Sensitive_Data_Logging Sensitive_Data_Logging Usa todas las funciones principales de la app mientras supervisas el registro del dispositivo. Verifica que no se registre información privada del usuario.
T-Hardware_IDs Hardware_IDs Usar todas las funciones principales de la app Verifica que la app no use ningún ID de hardware, como el IMEI, para fines de identificación.

Identidad

ID Función Descripción
T-Autofill_Hints Autofill_Hints Usar todas las funciones de la app que requieren la entrada del usuario Verifica que la app proporcione sugerencias para autocompletar los campos de entrada de datos, como las credenciales de la cuenta y otra información sensible.
T-Credential_Manager Credential_Manager Accede a tu app. Verifica que la app integre Credential Manager para Android para una experiencia de acceso que unifique la compatibilidad con llaves de acceso, identidades federadas y contraseñas.
T-Biometric_Authentication Biometric_Authentication Usar todas las funciones de la app que requieren autenticación Verifica que la app proteja las transacciones financieras o la información sensible, como los documentos importantes de los usuarios, con la autenticación biométrica.

Componentes de la aplicación

ID Función Descripción
T-Component_Export Component_Export Revisa todos los componentes de la aplicación definidos en el archivo de manifiesto de Android para el estado de exportación apropiado. La propiedad de exportación debe establecerse explícitamente para todos los componentes.
T-Component_Permissions Component_Permissions Revisa todos los permisos que tu app requiere en el archivo de manifiesto, el tiempo de ejecución y la configuración de la app en el dispositivo (Configuración > Información de la app).
T-Component_Protection Component_Protection Revisa todos los proveedores de contenido definidos en el archivo de manifiesto de Android. Asegúrate de que cada proveedor tenga un protectionLevel adecuado.

Redes

ID Función Descripción
T-Network_Security_Traffic Network_Security_Traffic Declara una configuración de seguridad de red que inhabilite el tráfico de texto simple y, luego, prueba la app.
T-Network_Security_Configuration Network_Security_Configuration Revisa la configuración de seguridad de red de la app. Verifica que no se produzca ningún error de configuración en las verificaciones de lint.
T-Security_Provider_Initialization Security_Provider_Initialization Verifica que el proveedor de seguridad se inicialice cuando se inicie la aplicación para los Servicios de Google Play.

WebViews

ID Función Descripción
T-WebView_Asset_Loader WebView_Asset_Loader Revisa la configuración de seguridad de red de la app. Verifica que no se produzca ningún error de configuración en las verificaciones de lint.
T-WebView_JavaScript WebView_JavaScript Para cada WebView, navega a una página que requiera JavaScript.
T-WebView_Navigation WebView_Asset_Loader,
WebView_JavaScript
En cada WebView, intenta navegar a sitios y contenido que tu app no cargue de forma directa.

Ejecución

ID Función Descripción
T-App_Bundles App_Bundles Verifica que la app use Android App Bundles y no cargue código de forma dinámica desde fuera del APK de la app.

Criptografía

ID Función Descripción
T-Cryptographic_Algorithms Cryptographic_Algorithms Verifica que la app use algoritmos criptográficos y un generador de números aleatorios sólidos proporcionados por la plataforma. Además, verifica que la app no implemente algoritmos personalizados.

Google Play

Verifica que tu app esté lista para Google Play.

Políticas

ID Función Descripción
T-Play_Content_Policies Play_Content_Policies,
Play_Content_Rating,
Play_User_Reviews
Inicia sesión en Google Play Console a fin de revisar tu perfil de desarrollador, la descripción de la app, las capturas de pantalla, el gráfico de funciones, la clasificación del contenido y los comentarios de los usuarios.

Página de detalles de la app

ID Función Descripción
T-Play_Feature_Graphic Play_Feature_Graphic Descarga tu gráfico de funciones y las capturas de pantalla, y reduce su tamaño de modo que coincidan con el de la pantalla de los dispositivos y factores de forma objetivo.
T-Play_Graphic_Assets Play_Feature_Graphic,
Play_Device_References,
Play_Misleading_Content
Revisa todos los recursos gráficos, el contenido multimedia, el texto, las bibliotecas de códigos y otros materiales incluidos en la descarga de la app o el archivo de expansión.

Archivar

Versiones anteriores de los principales lineamientos de calidad para apps: