在 EAS Build 上运行 E2E 测试
了解如何使用 Maestro 在 EAS Build 上设置和运行 E2E 测试。
随着 EAS Build 中对 E2E 测试的支持不断改进,本指南将随着时间的推移而发展。如果你正在寻找有关如何使用 Detox 在 EAS Build 上运行 E2E 测试的存档指南,你可以在 存档部分 中看到它。
在本指南中,你将学习如何使用 大师 在 EAS Build 上创建和运行 E2E 测试,大师 是运行移动应用中 E2E 测试的最流行工具之一。
¥In this guide, you will learn how to create and run E2E tests on EAS Build using Maestro, which is one of the most popular tools for running E2E tests in mobile apps.
该示例演示了如何使用 默认 Expo 模板 配置 EAS Build Maestro E2E 测试工作流。对于你自己的应用,你需要调整流程以匹配应用的 UI。
¥The example demonstrates how to configure your EAS Build Maestro E2E tests workflow using the default Expo template. For your own app, you will need to adjust the flows to match your app's UI.

1
初始化新项目
¥Initialize a new project
如果你已经有现有的 Expo 项目,则可以跳过此步骤。
¥You can skip this step if you already have an existing Expo project.
使用以下命令创建一个新项目:
¥Create a new project using the following commands:
# Initialize a new project- npx create-expo-app@latest eas-tests-example# Move into the project directory- cd eas-tests-example2
配置 EAS 构建
¥Configure EAS Build
如果你已经为项目配置了 EAS Build,则可以跳过此步骤。
¥You can skip this step if you already have EAS Build configured for your project.
以下命令在 Expo 服务器上为你的应用创建一个新项目,并在项目的根目录中创建 eas.json:
¥The following command creates a new project on Expo servers for your app and creates eas.json in the project's root directory:
- eas init- eas build:configure3
禁用新的 Android 构建基础架构
¥Disable New Android Builds Infrastructure
转到 项目设置 并禁用新的 Android 构建基础设施。
¥Go to Project settings and disable New Android Builds Infrastructure.
不幸的是,由于缺乏启动 Android 模拟器所需的虚拟化支持,新构建的基础架构与 E2E 测试不兼容。我们正在研究在 EAS 上运行各种测试的更好解决方案。
¥Unfortunately, the new build infrastructure is incompatible with E2E tests due to the lack of virtualization support required to start Android Emulator. We are working on better solutions for running various tests on EAS.
4
添加示例 Maestro 测试用例
¥Add example Maestro test cases
这是从默认 Expo 模板创建的应用的 UI 的样子:
¥This is what the UI of the app created from the default Expo template looks like:
让我们为示例应用创建两个简单的 Maestro 流程。首先在项目目录的根目录中创建一个名为 maestro 的目录。此目录将包含你将配置的流程,并且应与 eas.json 处于同一级别。
¥Let's create two simple Maestro flows for the example app. Start by creating a directory called maestro in the root of your project directory. This directory will contain the flows that you will configure and should be at the same level as eas.json.
在里面,创建一个名为 home.yml 的新文件。此流程将启动应用并断言文本 "欢迎!" 在主屏幕上可见。
¥Inside, create a new file called home.yml. This flow will launch the app and assert that the text "Welcome!" is visible on the home screen.
appId: dev.expo.eastestsexample # This is an example app id. Replace it with your app id.
---
- launchApp
- assertVisible: 'Welcome!'
接下来,创建一个名为 expand_test.yml 的新流程。此流程将在示例应用中打开 "探索" 屏幕,单击 "基于文件的路由" 可折叠项,并断言文本 "此应用有两个屏幕" 在屏幕上可见。
¥Next, create a new flow called expand_test.yml. This flow will open the "Explore" screen in the example app, click on the "File-based routing" collapsible, and assert that the text "This app has two screens" is visible on the screen.
appId: dev.expo.eastestsexample # This is an example app id. Replace it with your app id.
---
- launchApp
- tapOn: 'Explore.*'
- tapOn: '.*File-based routing'
- assertVisible: 'This app has two screens.*'
5
在本地运行 Maestro 测试
¥Run Maestro tests locally
要在本地运行 Maestro 测试,请按照 安装 Maestro 中的说明安装 Maestro CLI。
¥To run Maestro tests locally, install the Maestro CLI by following the instructions in Installing Maestro.
在本地 Android 模拟器或 iOS 模拟器上安装你的应用。打开终端,导航到 Maestro 目录,然后运行以下命令以使用 Maestro CLI 启动测试:
¥Install your app on a local Android Emulator or iOS Simulator. Open a terminal, navigate to the Maestro directory, and run the following commands to start the tests with the Maestro CLI:
- maestro test maestro/expand_test.yml- maestro test maestro/home.yml以下视频显示了 maestro/expand_test.yml 流程的成功运行:
¥The video below shows a successful run of the maestro/expand_test.yml flow:
6
创建自定义构建工作流程以运行 Maestro E2E 测试
¥Create a custom build workflow for running Maestro E2E tests
在 EAS Build 上运行 Maestro E2E 测试的最简单方法是创建 自定义构建工作流程。此工作流程将构建你的应用并在其上运行 Maestro 测试。
¥The easiest way to run Maestro E2E tests on EAS Build is to create a custom build workflow. This workflow will build your app and run the Maestro tests on it.
首先将自定义构建配置文件添加到你的项目。在项目中与 eas.json 同级的目录 .eas/build。两个目录的路径和名称对于 EAS Build 识别项目包含自定义构建配置非常重要。
¥Start by adding a custom build config file to your project. Create a directory .eas/build at the same level as eas.json in the project. The path and the name of both directories are important for EAS Build to identify that a project contains a custom build config.
在里面,创建一个名为 build-and-maestro-test.yml 的新配置文件。此文件定义你要运行的自定义构建工作流配置。工作流包含在自定义构建过程中执行的步骤。此自定义构建配置将执行 eas/build 自定义功能组以创建构建,然后执行 eas/maestro_test,这是一个一体化自定义功能组,用于安装 Maestro、准备测试环境(Android 模拟器或 iOS 模拟器)并使用 flow_path 输入指定的流程测试应用。
¥Inside, create a new config file called build-and-maestro-test.yml. This file defines the custom build workflow config that you want to run. Workflow contains steps that are executed during the custom build process. This custom build config will execute the eas/build custom function group to create a build and then the eas/maestro_test which is an all-in-one custom function group that installs Maestro, prepares a testing environment (Android Emulator or iOS Simulator) and tests the app using flows specified by the flow_path input.
build:
name: Create a build and run Maestro tests on it
steps:
  - eas/build
  - eas/maestro_test:
      inputs:
        flow_path: |
          maestro/home.yml
          maestro/expand_test.yml
现在通过添加一个名为 build-and-maestro-test 的新 建立档案 来修改 eas.json。它将用于从 build-and-maestro-test.yml 文件运行自定义构建配置。此配置将构建应用的模拟器/模拟器版本并在其上运行 Maestro 测试。
¥Now modify the eas.json by adding a new build profile called build-and-maestro-test. It will be used to run the custom build config from the build-and-maestro-test.yml file. This configuration will build the emulator/simulator version of your app and run the Maestro tests on it.
警告 我们观察到,如果在使用 Xcode 15.0 或 15.2 的图片上运行,Maestro 测试经常会超时。使用
latest图片 避免任何问题。¥We have observed that Maestro tests often time out if run on images with Xcode 15.0 or 15.2. Use the
latestimage to avoid any issues.
{
"build": {
  %%placeholder-start%%... %%placeholder-end%%
  "build-and-maestro-test": {
    "withoutCredentials": true,
    "config": "build-and-maestro-test.yml",
    "android": {
      "buildType": "apk",
      "image": "latest"
    },
    "ios": {
      "simulator": true,
      "image": "latest"
    }
  }
}
%%placeholder-start%%... %%placeholder-end%%
}
7
构建你的应用并在 EAS Build 上运行 E2E 测试
¥Build your app and run E2E tests on EAS Build
要使用 build-and-maestro-test 配置文件执行自定义构建,该配置文件将构建你的应用并随后运行 Maestro E2E 测试,请运行以下命令:
¥To execute a custom build using the build-and-maestro-test profile that will build your app and run the Maestro E2E tests afterward, run the following command:
- eas build --profile build-and-maestro-test当流程失败时,任何 Maestro 工件都会自动上传为构建工件。这包括保存在 ~/.maestro/tests(默认目标)的屏幕截图。你可以从构建页面下载它们。
¥When the flow fails, any Maestro artifacts are automatically uploaded as build artifacts. This includes screenshots saved at ~/.maestro/tests (the default destination). You can download them from the build page.
更多
¥More
如果你想构建更高级的自定义构建工作流程,请参阅 自定义构建架构参考 了解更多信息。
¥If you want to build more advanced custom builds workflows, see the custom build schema reference for more information.
要了解有关 Maestro 流程的更多信息以及如何编写它们,请参阅 Maestro 文档。
¥To learn more about Maestro flows and how to write them, see the Maestro documentation.
故障排除
¥Troubleshooting
如果你在 EAS Build 上启动用于 E2E 测试的 Android 模拟器时遇到以下错误消息:
¥If you encounter the following error message when starting an Android Emulator for E2E tests on EAS Build:
Failed to configure emulator: emulator with required ID not found.
这可能是因为你的项目启用了新构建基础设施。转到 项目设置 并禁用新的 Android 构建基础设施。
¥This is likely because the New Build Infrastructure is enabled for your project. Go to Project Settings and disable New Android Builds Infrastructure.