测试不同的屏幕和窗口尺寸

测试是应用开发过程中不可或缺的一部分。您通常会在模拟器或设备上运行应用,以手动验证您的代码是否按预期工作。但是,手动测试费时费力,容易出错,并且对于在各种尺寸的屏幕和设备上运行的应用来说,往往难以管理。手动测试的问题通常是由于开发中使用单个设备造成的。结果,错误可能会在其他具有不同外形的设备上被忽略。

为了识别不同窗口和屏幕尺寸上的回归,请实现自动化测试以验证您的应用的行为和外观在不同外形尺寸上是否一致。自动化测试可以尽早发现问题,从而降低问题影响用户体验的风险。

需要测试的内容

在为不同屏幕和窗口尺寸开发 UI 时,请特别注意以下两个方面:

  1. 组件和布局的可视属性在不同尺寸的窗口上有何不同
  2. 如何在配置更改中保留状态

可视属性

无论您是否为不同窗口尺寸定制 UI,都应验证 UI 是否正确显示。请考虑紧凑型、中等和扩展型宽度和高度。有关推荐断点,请参阅窗口尺寸类别

图 1.“为您推荐”屏幕在 Now In Android 中的不同窗口尺寸

此外,当您的应用设计系统中某些组件的大小约束被拉伸时,您的应用可能无法按预期呈现这些组件。

如果您的应用针对不同窗口尺寸具有自适应布局,则应进行自动化测试以防止出现回归。例如,修复手机上的边距可能会导致平板电脑上的布局不一致。创建UI 测试来验证布局和组件的行为,或构建屏幕截图测试来直观地验证布局。

状态恢复

在平板电脑等设备上运行的应用比手机上的应用更频繁地旋转和调整大小。此外,折叠式设备引入了新的显示功能,例如折叠和展开,这些功能可以触发配置更改。您的应用需要能够在发生这些配置更改时恢复状态。然后,您还需要编写测试来确认您的应用正确恢复状态。

图 2.折叠式设备折叠、完全打开、完全打开并旋转到横向以及半打开(桌面)状态。

首先,测试您的应用在发生配置更改时不会崩溃。确保您的应用中的每个 UI 都可以处理旋转、调整大小或折叠的任何组合。因为配置更改默认情况下会重新创建活动,所以一些崩溃是由于活动持久性的假设造成的。

有多种方法可以测试配置更改,但在大多数情况下,有两种方法可以测试:

  • 在 Compose 中,使用StateRestorationTester以高效的方式模拟配置更改,而无需重新启动活动。有关详细信息,请参阅以下部分。
  • 在任何 UI 测试(如 Espresso 或 Compose)中,通过调用Activity.recreate()来模拟配置更改。

通常,您无需使用不同的设备来测试响应配置更改的状态恢复。这是因为所有重新创建活动的环境配置更改都具有类似的影响。但是,某些配置更改可能会在特定设备上触发不同的状态恢复机制。

例如,当用户在打开的折叠式设备上查看列表-详情 UI 并将其折叠以切换到前显示屏时,UI 通常会切换到详情页面。自动化测试应涵盖此 UI 状态的恢复,包括导航状态。

要测试从一个显示屏到另一个显示屏或进入多窗口模式的设备上发生的配置更改,您可以选择多种方法:

  • 使用任何设备,在测试期间调整屏幕大小。在大多数情况下,这会触发您需要验证的所有状态恢复机制。但是,此测试不适用于检测折叠式设备中特定姿势的逻辑,因为姿势更改不会触发配置更改。
  • 使用支持您要测试的功能的设备或模拟器,触发相关的配置更改。例如,可以使用 Espresso Device 控制折叠式设备或平板电脑,以便从折叠状态移动到横向的完全打开状态。有关示例,请参阅用于测试不同屏幕尺寸的库和工具Espresso Device部分。
图 3.设备折叠和展开。

不同屏幕和窗口尺寸的测试类型

针对每种用例,使用合适的测试类型来验证测试在不同尺寸的设备上都能正常工作。

  • UI 行为测试启动应用程序 UI 的一部分,例如 Activity 的显示。测试验证某些元素是否存在或具有特定的属性。测试可以选择性地执行模拟用户操作。对于视图,请使用 Espresso。Jetpack Compose 有其自己的 测试 API。UI 行为测试可以是 Instrumented 测试本地测试。Instrumented 测试在设备或模拟器上运行,而本地 UI 测试在 JVM 上使用 Robolectric 运行。

    使用 UI 行为测试来验证应用程序的导航实现是否正确。测试执行点击和滑动等操作。UI 行为测试还会检查某些元素或属性的存在。更多信息,请参阅 自动化 UI 测试

  • 截图测试对 UI 或组件进行截图,并将图像与之前批准的截图进行比较。这是一种非常有效的防止回归的方法,因为单个截图可以涵盖大量元素及其视觉属性。您可以在 JVM 或设备上运行截图测试。有多个截图测试框架可用。更多信息,请参阅 截图测试

最后,您可能需要单元测试来测试逻辑单元的功能,这些单元的功能会根据设备类型或窗口大小的不同而不同,但在这一领域单元测试不太常见。

后续步骤

有关如何实现本文档中包含的检查的更多信息,请参阅 库和工具