Appetizer-Toolkit-Py - appetizer-toolkit 的 Python 代码封装


Apache
跨平台
Python

软件简介

appetizer-toolkit-py

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

appetizer-toolkit 是 Appetizer 的核心部分, 对所有 Android
设备提供以下功能:

  • 从单台设备录制屏幕触碰事件,在多台设备上重放 (需要屏幕横宽比一致)

  • 同时控制多台设备 (例如, 运行一个 shell 命令,安装 apk 等)

  • 将一台设备的屏幕触碰事件,镜像操作到多台设备上(需要屏幕横宽比一致)

安装要求

  • 下载 appetizer-toolkit.

  • 安装Android SDK自带的adb命令行工具,确保adb的路径在PATH环境变量中

  • 将需要调试的设备通过USB连接到开发机,并开启ADB调试(设置->开发者选项)。确保命令行执行adb devices可以看到连接的设备

安装

通过 pip支持Python 2.7, 3.x

pip install appetizer

使用

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

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

多设备控制

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())