Appetizer Replaykit Python SDK 使用指南 - 录制重放实时同步屏幕操作,控制多 Android 设备

appetizer.io · 发布于 2016年12月10日 · 最后由 qizhwei 回复于 2016年12月10日 · 845 次阅读

replaykit.py

Replaykit Python SDK 是对 replaykit的Python代码封装。 replaykit 可以在 Windows 7+, MacOS Mavericks+ 和 Linux x64上运行,同样本Python SDK也是跨平台的。

replaykit 是 Appetizer 实现多设备控制和录制重放功能的核心驱动, 对所有 Android 设备提供以下功能:

  • 从单台设备录制屏幕触碰事件,在多台设备上重放 (需要屏幕横宽比一致)
  • 同时控制多台设备 (例如, 运行一个 shell 命令,安装 apk 等)
  • 将一台设备的屏幕触碰事件,镜像操作到多台设备上(需要屏幕横宽比一致)

安装要求

  • 下载 replaykit
  • 安装Android SDK自带的adb命令行工具,确保adb的路径在PATH环境变量中
  • 将需要调试的设备通过USB连接到开发机,并开启ADB调试(设置->开发者选项)。确保命令行执行adb devices可以看到连接的设备

安装

通过 pip支持Python 2.7, 3.x

pip install appetizer

使用

所有的SDK API都通过Python标准的docstring提供详细的功能描述、参数类型、返回值类型等文档内容。开始使用前首先需要初始化一个 Appetizer 对象,后继所有的功能由这个对象提供。初始化需要提供replaykit的路径,如下:

from appetizer import Appetizer
appetizer = Appetizer(toolkit='path/to/the/toolkit/executable`) # e.g., './replaykit/linux/appetizer'

多设备控制

Appetizer 可以同时在多个设备上执行同一个命令,类似一个adb的多机版本:

# 列举所有已经连接的可以使用的设备
print (appetizer.devices.list())
# 获取一个设备的屏幕截图
appetizer.devices.take_screenshot("path/to/save/jpg/file", "serial_number")
# 安装APK文件到多个设备
appetizer.devices.control(["serialno1", "serialno2"], 'install', ['path/to/APK/file'])
# 启动一个APP
appetizer.devices.control(["serialno1", "serialno2"], 'launch_pkg', ['com.example.app'])
# 在多个设备上同时执行一个shell命令并获取返回信息
print(appetizer.devices.control(["serialno1", "serialno2"], 'shell', ['ls | grep system'])
# 镜像控制:将一个设备上的触摸屏输入实时投射到多个从属设备上
task = appetizer.devices.mirror("master_serialno", ["slave_serialno1", "slave_serialno2"])
# task对象代表了正在执行的镜像控制任务
time.sleep(5)
task.stop()

Trace管理

Trace 管理功能能够录制并重放触摸屏输入事件

# 从一个设备录制触屏输入
record_task = appetizer.trace.record("path/to/trace/file", "device_serial_number")
time.sleep(10)
record_task.stop()
# 向多个设备重放录制的触屏输入trace,要求多个设备与原设备有同样的纵宽比
appetizer.trace.replay("path/to/trace/file", ['serialno1', 'serialno2'])
# 获取trace的信息,例如长度、纵宽比等
print(appetizer.trace.get_info("path/to/trace/file"))

ADB server 控制

ADB是Appetizer与多个设备通讯的桥梁。adb命令行工具必须正确安装,并且adb server必须正常运行在开发机上。以下代码段展示了如何用本Python SDK控制本机的adb server:

# 检测本机以及安装的adb命令行工具(通过PATH环境变量)
print(appetizer.adb.detect_adb())
# 启动本机的 adb server
appetizer.adb.start_server()
# 停止本机的 adb server
appetizer.adb.kill_server()
# 检查本机adb server的运行情况
print(appetizer.adb.check_server())
如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
共收到 1 条回复
96

这次修好了一写平台bug,欢迎提出意见。

11797 appetizer.io Appetizer 移动开发 DevOps 平台发布 中提及了此贴 12月12日 12:27
需要 登录 后方可回复, 如果你还没有账号请点击这里 注册